前兩篇文章,我們分享了MySQL 5.7和mysql 8.0的一鍵安裝部署腳本。5.7和8.0兩個版本是工作中目前遇到最常用的兩個版本。5.7以前的版本在工作中用的比較少,但是在一些項目上還存在著5.6的版本。由于一些特殊的原因,應用程序對mysql 版本有特殊的要求,因此我們今天分享一下mysql5.6的部署方式。
解決方案
#!/bin/bash
#author:xuezhu
#date:20230325
#download mysql package
package="mysql-5.6.51-linux-glibc2.12-x86_64.tar.gz"
echo -n "please input start_port:"
read start_port
echo -n "please input end_port:"
read end_port
pts=$(seq ${start_port} ${end_port})
echo -n "please input innodb_pool_size,eg 512M,2G:"
read pool_size
innodb_pool_size=${pool_size}
echo -n "please input data_base dir:"
read base_dir
data_root=${base_dir}
#test.NETwork connecting
ping -c 3 www.baidu.com
if test $? -eq 0;then
mkdir software && cd software
#download package
#install linux package
yum install -y gcc gcc-c++ automake autoconf
yum -y install cmake bison-devel ncurses-devel libaio-devel
wget https://downloads.mysql.com/archives/get/p/23/file/$package
fi
#create mysql user and group
if test `cat /etc/passwd |grep mysql`;then
echo "mysql user already exist"
else
useradd -M -s /sbin/nologin mysql
fi
#unzip mysql package
tar -xzvf $package;
package_dir=$(basename ${package} .tar.gz)
for pt in $pts;
do
mkdir -p ${data_root}/$pt
cp -rpf ${package_dir}/* ${data_root}/$pt && mkdir -p ${data_root}/$pt/data
chown -R mysql:mysql ${data_root}/$pt
#config mysql configfile
cat >/etc/my$pt.cnf<<EOF
[mysql]
auto-rehash
socket =${data_root}/$pt/data/mysql$pt.sock # /tmp/mysql.sock
[mysqld]
####: for global
user =mysql # mysql
basedir =${data_root}/$pt/ # /usr/local/mysql/
datadir =${data_root}/$pt/data/ # /usr/local/mysql/data
server_id =$pt # 0
port =$pt # 3306
character_set_server =utf8 # latin1
log_bin_tRust_function_creators =ON # 0
max_prepared_stmt_count =1048576
socket =${data_root}/$pt/data/mysql$pt.sock # /tmp/mysql.sock
read_only =OFF # off
skip_name_resolve =1 # 0
auto_increment_increment =1 # 1
auto_increment_offset =1 # 1
lower_case_table_names =1 # 0
secure_file_priv = # null
open_files_limit =65536 # 1024
max_connections =512
thread_cache_size =64 # 9
table_open_cache =2000 # 2000
table_definition_cache =2000 # 1400
table_open_cache_instances =32 # 16
####: for binlog
binlog_format =ROW # row
log_bin =mysql-bin # off
binlog_rows_query_log_events =ON # off
log_slave_updates =ON # off
expire_logs_days =7 # 0
binlog_cache_size =96k # 65536(64k)
binlog_checksum =none # CRC32
sync_binlog =1 # 1
####: for error-log
log_error =err.log # /usr/local/mysql/data/localhost.localdomain.err
general_log =OFF # off
general_log_file =general.log # hostname.log
####: for slow query log
slow_query_log =ON # off
slow_query_log_file =slow.log # hostname.log
log_queries_not_using_indexes =OFF # off
long_query_time =2.0 # 10.000000
####: for gtid
gtid_mode =ON # off
enforce_gtid_consistency =ON # off
####: for replication
skip_slave_start =0 #
master_info_repository =table # file
relay_log_info_repository =table # file
rpl_semi_sync_master_enabled =1 # 0
rpl_semi_sync_slave_enabled =1 # 0
rpl_semi_sync_master_timeout =1000 # 1000(1 second)
plugin_load_add =semisync_master.so #
plugin_load_add =semisync_slave.so #
####: for innodb
default_storage_engine =innodb # innodb
default_tmp_storage_engine =innodb # innodb
innodb_data_file_path =ibdata1:256M;ibdata2:256M:autoextend # ibdata1:12M:autoextend
innodb_buffer_pool_filename =ib_buffer_pool # ib_buffer_pool
innodb_log_group_home_dir =./ # ./
innodb_log_files_in_group =8 # 2
innodb_log_file_size =128M # 50331648(48M)
innodb_file_per_table =ON # on
innodb_online_alter_log_max_size =128M # 134217728(128M)
innodb_open_files =64000 # 2000
innodb_page_size =16k # 16384(16k)
innodb_thread_concurrency =0 # 0
innodb_read_io_threads =4 # 4
innodb_write_io_threads =4 # 4
innodb_purge_threads =4 # 4
innodb_print_all_deadlocks =ON # off
innodb_lock_wait_timeout =50 # 50
innodb_spin_wait_delay =6 # 6
innodb_autoinc_lock_mode =2 # 1
innodb_io_capacity =4000 # 200
innodb_io_capacity_max =20000 # 2000
#--------Persistent Optimizer Statistics
innodb_stats_auto_recalc =ON # on
innodb_stats_persistent =ON # on
innodb_stats_persistent_sample_pages =20 # 20
innodb_buffer_pool_instances =10
innodb_adaptive_hash_index =ON # on
innodb_change_buffering =all # all
innodb_change_buffer_max_size =25 # 25
innodb_flush_neighbors =0 # 1
innodb_flush_method =O_DIRECT #
innodb_doublewrite =ON # on
innodb_log_buffer_size =256M # 16777216(16M)
innodb_flush_log_at_timeout =1 # 1
innodb_flush_log_at_trx_commit =1 # 1
innodb_buffer_pool_size =${innodb_pool_size} # 134217728(128M)
autocommit =ON # 1
#--------innodb scan resistant
innodb_old_blocks_pct =37 # 37
innodb_old_blocks_time =1000 # 1000
#--------innodb read ahead
innodb_read_ahead_threshold =1000 # 56 (0..64)
innodb_random_read_ahead =off # OFF
#--------innodb buffer pool state
innodb_buffer_pool_dump_at_shutdown =ON # ON
innodb_buffer_pool_load_at_startup =ON # ON
#### for performance_schema
performance_schema =off # on
performance_schema_consumer_global_instrumentation =on # on
performance_schema_consumer_thread_instrumentation =on # on
performance_schema_consumer_events_stages_current =on # off
performance_schema_consumer_events_stages_history =on # off
performance_schema_consumer_events_stages_history_long =off # off
performance_schema_consumer_statements_digest =on # on
performance_schema_consumer_events_statements_current =on # on
performance_schema_consumer_events_statements_history =on # on
performance_schema_consumer_events_statements_history_long =off # off
performance_schema_consumer_events_waits_current =on # off
performance_schema_consumer_events_waits_history =on # off
performance_schema_consumer_events_waits_history_long =off # off
EOF
##config mysql startup script
cat<<EOF > /etc/init.d/mysql$pt
port=$pt
mysql_user="root"
cmdpath="${data_root}/${pt}/bin"
mysql_sock="${data_root}/${pt}/data/mysql$pt.sock"
#pidname="$(hostname)"
mysqld_pid_file_path="${data_root}/${pt}/data/$(hostname).pid"
start(){
if [ ! -e "$mysql_sock" ];then
printf "Starting MySQL...n"
${cmdpath}/mysqld --defaults-file=/etc/my${pt}.cnf --user=${mysql_user} 2>/dev/null &
sleep 3
else
printf "MySQL is running...n"
exit 1
fi
}
stop(){
if [ ! -e "$mysql_sock" ];then
printf "MySQL is stopped...n"
exit 1
else
printf "Stoping MySQL...n"
mysqld_pid=`cat "$mysqld_pid_file_path"`
if (kill -0 $mysqld_pid 2>/dev/null)
then
kill $mysqld_pid
sleep 2
else
rm $mysqld_pid_file_path
fi
fi
}
restart(){
printf "Restarting MySQL...n"
stop
sleep 2
start
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
*)
printf "Usage: /etc/init.d/mysql${pt} {start|stop|restart}n"
esac
EOF
#initial mysql5.6
${data_root}/$pt/scripts/mysql_install_db --user=mysql --defaults-file=/etc/my$pt.cnf --basedir=${data_root}/$pt
#startup mysqlserver
chmod 755 /etc/init.d/mysql${pt}
/etc/init.d/mysql${pt} start
if [ $? -eq 0 ];then
sleep 20
#modify mysqlserver password
${data_root}/$pt/bin/mysql -hlocalhost -uroot -P${pt} -S ${data_root}/${pt}/data/mysql$pt.sock -e "UPDATE mysql.user SET password = PASSWORD('Rootasdf2023') WHERE user = 'root';flush privileges;"
if [ $? -eq 0 ];then
echo "MySQL INSTANCE $pt is install sucessed!"
else
echo "MySQL INSTANCE $pt is install maybe failed!please you check"
fi
else
break
fi
done
解決方案說明
1、配置文件參數是mysql 5.6的
2、安裝成功后root的初始密碼是:Rootasdf2023
3、運行腳本時,只需要輸入開始端口號,結束端口號、innodb_buffer_size的大小、安裝目錄即可。
4、Mysql各實例配置文件路徑為:/etc/my{port}.cnf
5、Mysql各實例配置文件路徑為:/etc/init.d/mysql{port}
5.6和5.7部署腳本的差異
1、依賴的軟件包,mysql5.6需要安裝額外的一些軟件包,具體詳見腳本內容。
2、配置文件的不同,5.6和5.7的參數還是存在著較大的差異。
3、數據庫初始化和密碼初始化的方式不同。
小結
通過把日常的部署進行腳本化,工具化,可以大大提高部署的效率,減少部署的時間。此腳本已經在測試機進行驗證無誤,喜歡的朋友可以收藏和點贊。