Cara Membuat User MySQL Berikut Database dan Privileges

Berikut adalah snippet singkat bagi jenengan yang ingin membuat user MySQL berikut dengan akses database yang sama. Gunakan terminal/konsole untuk melakukan perintah-perintah berikut:


mysql -u namauserroot -p

untuk membuat database: Continue reading Cara Membuat User MySQL Berikut Database dan Privileges

Facebook, Google and Others Announce MySQL fork, WebScaleSQL Project

webscalesqlA number of tech companies including Facebook, Google, LinkedIn, and Twitter announced WebScaleSQL on Thursday as a project that adapts MySQL to their massively bigger database needs.

WebScaleSQL is a branch of MySQL designed to run MySQL at scale and gaining maximum performance from the database.

The WebScaleSQL.org project site says, “We aim to create a more integrated system of knowledge-sharing to help companies leverage the great features already found in MySQL 5.6, while building and adding more features that are specific to deployments in large scale environments. In the last few months, engineers from all four companies have contributed code and provided feedback to each other to develop a new, more unified, and more collaborative branch of MySQL.” 

Backup MySQL tabel per tabel dengan rotasi otomasi

Berikut ini adalah MySQL backup script yang dapat mengambil tabel dengan backup tabel (file cadangan individu masing-masing tabel database masing-masing) dalam format terkompresi. Hal ini juga memberikan rotasi otomatis dari file backup yang lama. Script cadangan menangani tabel InnoDB dan MyISAM secara terpisah.

Anda harus mengatur variabel-variabel berikut sebelum menjalankan skrip backup.

DB_User

Database user yang memiliki akses ke semua database dan tabel. Saya menggunakan “root” untuk penyebaran saya.

DB_PASS

Password dari pengguna di atas, diawali dengan “-p”. Misalnya jika password yang Rahasia, maka Anda harus menulis password sebagai “-pSecret”.

BAKUP_LOG

File untuk yang log cadangan akan ditulis. Ini harus dapat ditulis oleh user yang menjalankan script.

BASE_BAK_FLDR

Folder backup. Ini harus dapat ditulis oleh user yang menjalankan script.

RM_FLDR_DAYS

Contoh

Rotasi backup +30 artinya backup tiap 30 hari sekali. Script ditulis oleh Mohammed Salih/HowToForge.com

#!/bin/bash
# Database Backup script.
# Created By:    Mohammed Salih
#                 Senior System Administrator
#                Date: 21/06/2007
#
# Database credentials
DB_USER=root
#Please append password in the xxxxx section below, note that there is
# no space between -p and xxxxx
DB_PASS="-pxxxxxxx"
# Get list of Databases except the pid file
DBS_LIST=$(echo "show databases;"|mysql -u $DB_USER $DB_PASS -N)
# Log file
BAKUP_LOG=/backup/log/db-backup.log
# Backup Base directory
BASE_BAK_FLDR=/backup/db
# Backup rotation period.
RM_FLDR_DAYS="+30"
# From here, only edit if you know what you are doing.
index=0
# Check if we can connect to the mysql server; otherwise die
if [ ! "$(id -u -n)" = "mysql" ]; then
        echo -e "Error:: $0 : Only user 'mysql' can run this script"
        exit 100
fi
PING=$(mysqladmin ping -u $DB_USER $DB_PASS 2>/dev/null)
if [ "$PING" != "mysqld is alive" ]; then
        echo "Error:: Unable to connected to MySQL Server, exiting !!"
        exit 101
fi
# Backup process starts here.
# Flush logs prior to the backup.
mysql -u $DB_USER $DB_PASS -e "FLUSH LOGS"
# Loop through the DB list and create table level backup,
# applying appropriate option for MyISAM and InnoDB tables.
for DB in $DBS_LIST; do
    DB_BKP_FLDR=$BASE_BAK_FLDR/$(date +%d-%m-%Y)/$DB
    [ ! -d $DB_BKP_FLDR ]  && mkdir -p $DB_BKP_FLDR
    # Get the schema of database with the stored procedures.
    # This will be the first file in the database backup folder
    mysqldump -u $DB_USER $DB_PASS -R -d --single-transaction $DB | \
            gzip -c > $DB_BKP_FLDR/000-DB_SCHEMA.sql.gz
    index=0
    #Get the tables and its type. Store it in an array.
    table_types=($(mysql -u $DB_USER $DB_PASS -e "show table status from $DB" | \
            awk '{ if ($2 == "MyISAM" || $2 == "InnoDB") print $1,$2}'))
    table_type_count=${#table_types[@]}
    # Loop through the tables and apply the mysqldump option according to the table type
    # The table specific SQL files will not contain any create info for the table schema.
    # It will be available in SCHEMA file
    while [ "$index" -lt "$table_type_count" ]; do
        START=$(date +%s)
        TYPE=${table_types[$index + 1]}
        table=${table_types[$index]}
        echo -en "$(date) : backup $DB : $table : $TYPE "
        if [ "$TYPE" = "MyISAM" ]; then
            DUMP_OPT="-u $DB_USER $DB_PASS $DB --no-create-info --tables "
        else
            DUMP_OPT="-u $DB_USER $DB_PASS $DB --no-create-info --single-transaction --tables"
        fi
        mysqldump  $DUMP_OPT $table |gzip -c > $DB_BKP_FLDR/$table.sql.gz
        index=$(($index + 2))
        echo -e " - Total time : $(($(date +%s) - $START))\n"
    done
done
# Rotating old backup. according to the 'RM_FLDR_DAYS'
if [ ! -z "$RM_FLDR_DAYS" ]; then
    echo -en "$(date) : removing folder : "
    find $BASE_BAK_FLDR/ -maxdepth 1 -mtime $RM_FLDR_DAYS -type d -exec rm -rf {} \;
    echo
fi

Lokasi backup di atur pada: $BKP_BASE_FLDR/01-01-2007/bigdb

How to use MySQL Query Browser on Remote Database on Mandriva

MySQL Query Browser is a part of MySQL database product from MySQL (now it owned by Oracle,Inc.). It is a GUI tool to run MySQL Query and get the result on pretty field-way view. MySQL Query browser mostly used by administrator on it own server, altough it can be managing a remote database query. Here is the how-to:

1. Install the MySQL Query Browser with urpmi on Mandriva 2010.1


urpmi --auto-update

urpmi mysql-query-browser

2. Now, run the terminal/Konsole. Continue reading How to use MySQL Query Browser on Remote Database on Mandriva

Belajar PHP: Membuat Cron Backup database + kirim hasil ke email Gmail

Backup adalah aksi wajib bagi pengelolaan sebuah sistem. Ada banyak cara dan jalan dalam membuat backup, dari yang manual sampai yang otomatis. Teknik backup data yang akan kita lakukan kali ini akan memanfaatkan skrip PHP untuk membackup database, memampatkannya menjadi format GZIP dan mengirimnya ke email Gmail. Kenapa Gmail? Karena Gmail menawarkan storage yang besar untuk tiap akunnya (sekitar 7Giga lebih saat artikel ini dipublish).

Ada beberapa software/pustaka yang akan kita gunakan, antara lain mysqldump bawaan MySQL, class PHPMailer dan aplikasi gzip bawaan Linux. Berikut contoh skripnya: Continue reading Belajar PHP: Membuat Cron Backup database + kirim hasil ke email Gmail

Tutorial MySQL Multi Master Replication dengan Galera

Untuk mengikuti tutorial ini setidaknya anda membutuhkan 4 server, 3 server sebagai uji coba kluster server MySQL dan 1 sebagai load balancer. Install dan buat 4 server Linux dengan Virtualbox/VMWare.

Tutorial ini menggunakan skenario 3 server replika untuk menangani seluruh request dari Client dengan ip address sebagai berikut:
mysql1: 192.168.1.138/24
mysql2: 192.168.1.139/24
mysql3: 192.168.1.140/24

Dalam kluster ini, server mysql2 akan terkoneksi ke mysql1 dan server mysql3 ke mysql2. Jika koneksi antara mysql2 dan mysql3 sudah terbangun, komunikasi antara mysql1 ke mysql3 akan dibentuk secara otomatis dengan komunikasi satu arah (termasuk ke semua node pada kluster).

Instalasi MySQL

# apt-get install libaio1 libdbi-perl libdbd-mysql-perl mysql-client rsync

Install MySQL server dengan wsrep patch

Debian/Ubuntu 32 bits:

# wget https://launchpad.net/codership-mysql/5.5/5.5.28-23.7/+download/mysql-server-wsrep-5.5.28-23.7-i386.deb && dpkg -i mysql-server-wsrep-5.5.28-23.7-i386.deb

Debian/Ubuntu 64 bits:

# wget https://launchpad.net/codership-mysql/5.5/5.5.28-23.7/+download/mysql-server-wsrep-5.5.28-23.7-amd64.deb && dpkg -i mysql-server-wsrep-5.5.28-23.7-amd64.deb

Download dan install Galera

– 32 bits:

# wget https://launchpad.net/galera/2.x/23.2.2/+download/galera-23.2.2-i386.deb && dpkg -i galera-23.2.2-i386.deb

– 64 bits:

# wget https://launchpad.net/galera/2.x/23.2.2/+download/galera-23.2.2-amd64.deb && dpkg -i galera-23.2.2-amd64.deb

Konfigurasi Awal MySQL

# /etc/init.d/mysql start
# mysql -u root
mysql> DELETE FROM mysql.user WHERE user='';
mysql> GRANT ALL ON *.* TO root@'%' IDENTIFIED BY 'P@ssw0rd';
mysql> UPDATE mysql.user SET Password=PASSWORD('P@ssw0rd') WHERE User='root';
mysql> GRANT ALL ON *.* to sst@'%' IDENTIFIED BY 'sstpasswd';

Atur supaya mysqld dijalankan sesaat setelah booting up:

# update-rc.d mysql defaults

Konfigurasi Server MySQL1

# vi /etc/mysql/conf.d/wsrep.cnf
 
# Full path to wsrep provider library or 'none'
wsrep_provider=/usr/lib/galera/libgalera_smm.so
 
# Group communication system handle
wsrep_cluster_address="gcomm://"
 
# State Snapshot Transfer method
wsrep_sst_method=rsync
 
# SST authentication string. This will be used to send SST to joining nodes.
# Depends on SST method. For mysqldump method it is root:
wsrep_sst_auth=sst:sstpasswd
# /etc/init.d/mysql restart

NB. Untuk sementara, alamat node masih gcomm://, selanjutnya akan dikonfigurasi pada server 3.

Konfigurasi Server MySQL2

# vi /etc/mysql/conf.d/wsrep.cnf
 
# Full path to wsrep provider library or 'none'
wsrep_provider=/usr/lib/galera/libgalera_smm.so
 
# Group communication system handle
wsrep_cluster_address="gcomm://192.168.1.138:4567"
 
# State Snapshot Transfer method
wsrep_sst_method=rsync
 
# SST authentication string. This will be used to send SST to joining nodes.
# Depends on SST method. For mysqldump method it is root:
wsrep_sst_auth=sst:sstpasswd
# /etc/init.d/mysql restart

Konfigurasi Server MySQL3

# vi /etc/mysql/conf.d/wsrep.cnf
 
# Full path to wsrep provider library or 'none'
wsrep_provider=/usr/lib/galera/libgalera_smm.so
 
# Group communication system handle
wsrep_cluster_address="gcomm://192.168.1.139:4567"
 
# State Snapshot Transfer method
wsrep_sst_method=rsync
 
# SST authentication string. This will be used to send SST to joining nodes.
# Depends on SST method. For mysqldump method it is root:
wsrep_sst_auth=sst:sstpasswd
# /etc/init.d/mysql restart

Konfigurasi Ulang Server MySQL1

# vi /etc/mysql/conf.d/wsrep.cnf
 
wsrep_cluster_address="gcomm://192.168.1.140:4567"
# mysql -u root -p
mysql> set global wsrep_cluster_address='gcomm://192.168.1.140:4567';

Checking wsrep variables

mysql> show status like 'wsrep%';
+----------------------------+----------------------------------------------------------+
| Variable_name | Value |
+----------------------------+----------------------------------------------------------+
| wsrep_local_state_uuid | 17048124-4c6e-11e2-0800-5c8217cefd3f |
| wsrep_protocol_version | 4 |
| wsrep_last_committed | 1 |
| wsrep_replicated | 0 |
| wsrep_replicated_bytes | 0 |
| wsrep_received | 10 |
| wsrep_received_bytes | 1039 |
| wsrep_local_commits | 0 |
| wsrep_local_cert_failures | 0 |
| wsrep_local_bf_aborts | 0 |
| wsrep_local_replays | 0 |
| wsrep_local_send_queue | 0 |
| wsrep_local_send_queue_avg | 0.000000 |
| wsrep_local_recv_queue | 0 |
| wsrep_local_recv_queue_avg | 0.000000 |
| wsrep_flow_control_paused | 0.000000 |
| wsrep_flow_control_sent | 0 |
| wsrep_flow_control_recv | 0 |
| wsrep_cert_deps_distance | 0.000000 |
| wsrep_apply_oooe | 0.000000 |
| wsrep_apply_oool | 0.000000 |
| wsrep_apply_window | 0.000000 |
| wsrep_commit_oooe | 0.000000 |
| wsrep_commit_oool | 0.000000 |
| wsrep_commit_window | 0.000000 |
| wsrep_local_state | 4 |
| wsrep_local_state_comment | Synced |
| wsrep_cert_index_size | 0 |
| wsrep_causal_reads | 0 |
| wsrep_incoming_addresses | 192.168.1.138:3306,192.168.1.140:3306,192.168.1.139:3306 |
| wsrep_cluster_conf_id | 5 |
| wsrep_cluster_size | 3 |
| wsrep_cluster_state_uuid | 17048124-4c6e-11e2-0800-5c8217cefd3f |
| wsrep_cluster_status | Primary |
| wsrep_connected | ON |
| wsrep_local_index | 0 |
| wsrep_provider_name | Galera |
| wsrep_provider_vendor | Codership Oy <info@codership.com> |
| wsrep_provider_version | 23.2.2(r137) |
| wsrep_ready | ON |
+----------------------------+----------------------------------------------------------+
40 rows in set (0.00 sec)

The most important variables are wsrep_ready, if the value is ON it means that the cluster is working, and wsrep_cluster_size that is equals to the number of nodes that is composed the cluster.

SkySQL Announce Merging with MariaDB

SkySQL today announced that it has signed a merger agreement with Monty Program Ab, creators of the fastest growing open source database technology: MariaDB.  This merger reunites key members of the original MySQL AB developer and services teams. Their aim is to develop MariaDB into a truly interoperable, NewSQL open source database in collaboration with its customers, partners and the community. The company also pledges to further evolve its offering for users of the MySQL database.

MariaDB is truly open source and is compatible with the MySQL database while providing new extensions and features. Customers and users move to MariaDB for its performance. It is uniquely capable of interfacing with NoSQL database systems like Cassandra and LevelDB as well as to access data in other formats thanks to pluggable storage engines. This allows customers to leverage the capabilities of the latest database technologies as well as access data in legacy systems without expensive and risky database migrations. This merger brings cloud and big data capabilities together, which will enable the new company to become an interface for fellow open source technology providers. Continue reading SkySQL Announce Merging with MariaDB

Belajar SQL: Select Data Di Tabel A Yang tidak Ada di Tabel B

Tips singkat berikut berisi query yang mungkin berguna bagi anda yang mencari query SQL yang digunakan untuk mencari data di tabel A yang tidak ada di tabel B. Contoh kasus, jika A adalah tabel master dan tabel B adalah tabel data isian, maka anda diminta untuk mencari data siapa yang belum mengisi. Sehingga logika yang dibangun adalah, select data ditabel A yang tidak ada di tabel B.

Sintaks yang dipakai adalah dengan sintaks NOT EXISTS. Contoh:

SELECT * FROM tabel_a WHERE NOT EXISTS (SELECT * FROM tabel_b)

Continue reading Belajar SQL: Select Data Di Tabel A Yang tidak Ada di Tabel B

How to Compressing MySQLdump output file

The result of mysqldump is a flat text file containing the sql commands used to restore the mysql databases/tables that were dumped. Normally the result of mysqldump is compressed (in regular backups) because the size of the resulted file is normally big and good compression rates are achieved on such text files.
To do this manually using gzip we just run:

gzip -v outputfile.sql

This quick tip shows how you can run the same thing on the fly with only one command directly compressing the resulted file. Continue reading How to Compressing MySQLdump output file

Backup/Restore Database MySQL dengan PHP Berkemampuan Multithreaded

Backup dan restore database MySQL adalah kegiatan rutin harian seorang administrator. Berbagai tool dan script mungkin digunakan dan dijalankan secara otomatis oleh cron setiap harinya. Semakin besar database yang dicadangkan, semakin lama waktu yang dibutuhkan. Kebanyakan tool backup hanya bekerja tunggal, belum bisa multithreading. Nah, bagaimana jika anda ingin melakukan backup dan restore MySQL sampai pada tataran tabel per tabel? sehingga hanya tabel-tabel transaksi penting yang akan dibackup harian? dan bisa berjalan multithread?

Solusinya ada di ASHDumper, sebuah script PHP buatan om Aziz Saleh Hussain (dari Amerika) yang baru saja memenangkan PHPClasses Inovation Award of The Month (bulan September 2012). ASHDumper sebagai tool backup akan membackup tabel per tabel MySQL dengan 1 thread (1 service) tiap tabelnya, sehingga proses lebih berjalan cepat karena multithreading. Untuk dapat menggunakan ASHDumper, PHP/MySQL anda harus memenuhi syarat berikut:
– proc_open enabled (lihat php.ini)
– akses ke mysql atau mysqldump
– direktori output yang writeable Continue reading Backup/Restore Database MySQL dengan PHP Berkemampuan Multithreaded

MariaDB is Release their own Clustering Version of MySQL

onty Program’s MariaDB team has announced the first availability of MariaDB Galera, a clustering solution that is the result of a partnership between the MariaDB team and Codership. The alpha release, which should not be used for production systems, includes a merge of MariaDB 5.5.25 with Galera Cluster from Codership in a combination that is said to offer a read/write scalable system, synchronous multi-master replication and guaranteed data consistency.

“We’ve received a significant amount of requests for a MariaDB based Galera cluster and today we’re proud to deliver that,” said Michael “Monty” Widenius, adding that Monty Program and partners are preparing to roll out the GA product and, via SkySQL, professional services, in what is planned to be a rapid release cycle, Codership’s Galera Cluster software was originally developed for MySQL. Continue reading MariaDB is Release their own Clustering Version of MySQL

Konfigurasi MySQL untuk Trafik Tinggi

Secara default MySQL hadir dengan konfigurasi yang sudah cukup mumpuni melayani request database puluhan orang, apalagi kalau cuma sekedar melayani testing environment oleh sang Developer saja. Namun jika pengguna aplikasi anda ini ratusan atau bahkan ribuan, anda harus melakukan tuning ulang untuk server bertrafik tinggi.

Untuk melakukan konfigurasi tersebut, silakan buka file my.cnf pada direktori /etc/mysql/my.cnf (jika anda menggunakan linux) atau C:\xampp\mysql\bin\my.ini.

Silakan pakai dan ubah konfigurasi yang saya rekomendasikan berikut: Continue reading Konfigurasi MySQL untuk Trafik Tinggi

Twitter will Changes Tweet Storage Strategy (via TechCrunch)

An interesting post just went up on the Twitter Engineering blog. Usually, that blog contains posts that are more interesting to developers working on Twitter’s platform. And this post is that as well, but it also states two much larger things. First, Twitter won’t be using the Cassandra database system to store tweets. Second, Cassandra will be used for Twitter’s realtime analytics product. The one they haven’t officially announced yet.
It’s been believed for some time that analytics would eventually be a part of Twitter’s monetization strategy, but they’ve never said much about it beyond vague statements about it being one potential idea. ReadWriteWeb’s Marshall Kirkpatrick dug up some evidence that it would be launching soon (which we also believe to be the case) two days ago. And in this post tonight, Twitter’s Ryan King writes the following, “Our analytics, operations and infrastructure teams are working on a system that uses cassandra for large-scale real time analytics for use both internally and externally.” Continue reading Twitter will Changes Tweet Storage Strategy (via TechCrunch)

Membuat Sistem Informasi Akademik (Part 2: Desain dan Hirarki Folder)

Menyambung intro tentang rangkaian tutorial terkait pembuatan Sistem Informasi Akademik berbasis PHP – MySQL ini, kali ini kita akan membahas tentang desain dan hirarki folder aplikasi. Untuk folder aplikasi ini sendiri, seperti kebanyakan aplikasi berbasis web lain, aplikasi akan ditaruh pada folder aktif apache (misalnya htdocs, atau public_html), nama dan letak folder aktif ini bergantung dari konfigurasi Apache yang anda miliki. (Silakan lihat file httpd.conf).

Adapun hirarki folder aplikasi yang akan kita pakai, sebagai berikut:

Ada 5 folder utama pada aplikasi yang akan kita kembangkan: Continue reading Membuat Sistem Informasi Akademik (Part 2: Desain dan Hirarki Folder)

Membuat Sistem Informasi Akademik (Part 1: Design Aplikasi)

Insyaallah, lewat laman ini saya akan mempublish beberapa tutorial singkat tentang pembuatan Sistem Informasi Akademik berbasis Web yang sekarang sudah mulai banyak dipakai dan dibutuhkan oleh pelbagai perguruan tinggi dan satuan pendidikan. Kenapa berbasis web? mungkin karena mudah dikembangkan, baik untuk intranet dan internet.

Pada bagian 1 kali ini, kita akan bicara tentang desain aplikasi yang akan coba kita kembangkan.

  • Sistem dikembangkan dengan PHP dan MySQL,
  • Sistem didesain dapat diinstal pada server berbasis Apache, baik versi Windows maupun Linux,
  • Sistem menggunakan interface HTML yang dilengkapi dengan tampilan berbasis CSS,
  • Sistem memaksimalkan penggunaan teknologi AJAX, khususnya JQuery,
  • Sistem mampu menghasilkan file report berupa file Excel dan PDF,
  • Sebisa mungkin sistem dikembangkan dengan penggabungan tradisi pemrograman prosedural dan OOP, tidak dikembangkan dengan framework apapun (untuk sementara)
  • Sistem didesain secara terpusat dengan pengelolaan mulai dari tingkat satuan tertinggi (Universitas/Direktur) sampai satuan terendah, Program Studi/Jurusan.
    Continue reading Membuat Sistem Informasi Akademik (Part 1: Design Aplikasi)