首页 💬 Database

1. 安装MySQL

1.1 下载软件

mkdir -p /opt/software
cd /opt/software
wget http://download.iuskye.com/Mysql/software/generic/mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz

1.2 设置环境变量

export Mysql_pkg_path='/opt/software/mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz'
export Deploy_path='/opt'
export USER=`whoami`

1.3 下载解压创建目录

sudo tar xf ${Mysql_pkg_path} -C ${Deploy_path}/ 
sudo ln -s ${Deploy_path}/mysql-5.7.26-linux-glibc2.12-x86_64/ ${Deploy_path}/mysql
sudo mkdir -p /data/mysql

1.4 修改启动脚本

sudo sed -i '46s#basedir=#basedir=/opt/mysql#' ${Deploy_path}/mysql/support-files/mysql.server
sudo sed -i '47s#datadir=#datadir=/data/mysql#' ${Deploy_path}/mysql/support-files/mysql.server
sudo sed -i "375aLimitNOFILE=infinity\nLimitMEMLOCK=infinity\n" ${Deploy_path}/mysql/support-files/mysql.server
sudo cp ${Deploy_path}/mysql/support-files/mysql.server /etc/init.d/mysqld
sudo chmod 755 /etc/init.d/mysqld

1.5 创建用户

sudo groupadd mysql
sudo useradd -r -g mysql -s /bin/false mysql

1.6 赋予data目录和base目录普通用户组

sudo chown -R ${USER}.${USER} ${Deploy_path}/mysql/
sudo chown -R ${USER}.${USER} /data/mysql

1.7 初始化

${Deploy_path}/mysql/bin/mysqld --initialize --user=mysql --basedir=${Deploy_path}/mysql --datadir=/data/mysql 2>&1 | tee -a /tmp/init_mysql.log

1.8 过滤初始密码

mysql_passwd=$(grep "password" /tmp/init_mysql.log | awk -F' ' '{print $11}')
sudo ln -s /opt/mysql/bin/mysql /usr/bin/

1.9 创建配置文件

sudo rm -f /etc/my.cnf
sudo bash -c "cat >> /etc/my.cnf" <<EOF
[mysqld]
#****************************** basic ******************************
datadir                             = /data/mysql
basedir                             = ${Deploy_path}/mysql
port                                = 3306
socket                              = /data/mysql/mysql.sock
pid_file                            = /data/mysql/mysql.pid
#****************************** connection ******************************
max_connections                     = 30000
max_connect_errors                  = 100000
max_user_connections                = 6000
check_proxy_users                   = on
mysql_native_password_proxy_users   = on
local_infile                        = OFF
symbolic-links                      = FALSE
#****************************** sql timeout & limits ******************************
max_join_size                       = 1000000
max_execution_time                  = 10000
lock_wait_timeout                   = 60
autocommit                          = 1
lower_case_table_names              = 1
thread_cache_size                   = 64
disabled_storage_engines            = "MyISAM,FEDERATED"
character_set_server                = utf8
transaction-isolation               = "READ-COMMITTED"
skip_name_resolve                   = ON
explicit_defaults_for_timestamp     = ON
log_timestamps                      = SYSTEM
local_infile                        = OFF
event_scheduler                     = OFF
query_cache_type                    = OFF
query_cache_size                    = 0
#lc_messages                        = en_US
#lc_messages_dir                    = /data/mysql/share
init_connect                        = "set names utf8"
#sql_mode                           = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO
sql_mode                            = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
init_file                           = /data/mysql/init_file.sql
#init_slave
#****************************** err & slow & general ******************************
log_error                               = /data/mysql/mysql.err
#log_output                             = "TABLE,FILE"
slow_query_log                          = ON
slow_query_log_file                     = /data/mysql/slow.log
long_query_time                         = 1
log_queries_not_using_indexes           = ON
log_throttle_queries_not_using_indexes  = 10
general_log                             = OFF
general_log_file                        = /data/mysql/general.log
#****************************** binlog & relaylog ******************************
expire_logs_days                    = 99
sync_binlog                         = 1
#log-bin                            = /data/mysql/blog/mysql-bin
#log-bin-index                      = /data/mysql/blog/mysql-bin.index
max_binlog_size                     = 500M
binlog_format                       = ROW
binlog_rows_query_log_events        = ON
binlog_cache_size                   = 128k
binlog_stmt_cache_size              = 128k
max_binlog_cache_size               = 2G
max_binlog_stmt_cache_size          = 2G
#relay_log                          = /data/mysql/blog/relay
#relay_log_index                    = /data/mysql/blog/relay.index
max_relay_log_size                  = 500M
relay_log_purge                     = ON
relay_log_recovery                  = ON
#****************************** rpl_semi_sync ******************************
#rpl_semi_sync_master_enabled                = ON
#rpl_semi_sync_master_timeout                = 1000
#rpl_semi_sync_master_trace_level            = 32
#rpl_semi_sync_master_wait_for_slave_count   = 1
#rpl_semi_sync_master_wait_no_slave          = ON
#rpl_semi_sync_master_wait_point             = AFTER_SYNC
#rpl_semi_sync_slave_enabled                 = ON
#rpl_semi_sync_slave_trace_level             = 32
#****************************** group commit ******************************
#binlog_group_commit_sync_delay              =1
#binlog_group_commit_sync_no_delay_count     =1000
#****************************** gtid ******************************
#gtid_mode                          = ON
#enforce_gtid_consistency           = ON
#master_verify_checksum             = ON
#sync_master_info                   = 1
#****************************** slave ******************************
#skip-slave-start                   = 1
##read_only                         = ON
##super_read_only                   = ON
#log_slave_updates                  = ON
#server_id                          = 336001
#report_host                        = 172.31.40.45
#report_port                        = 3360
#slave_load_tmpdir                  = /msdata/db_mysql/tmp
#slave_sql_verify_checksum          = ON
#slave_preserve_commit_order        = 1
#****************************** muti thread slave ******************************
#slave_parallel_type                = LOGICAL_CLOCK
#slave_parallel_workers             = 4
#master_info_repository             = TABLE
#relay_log_info_repository          = TABLE
#****************************** buffer & timeout ******************************
read_buffer_size                    = 1M
read_rnd_buffer_size                = 2M
sort_buffer_size                    = 1M
join_buffer_size                    = 1M
tmp_table_size                      = 64M
max_allowed_packet                  = 64M
max_heap_table_size                 = 64M
connect_timeout                     = 10
wait_timeout                        = 600
interactive_timeout                 = 600
net_read_timeout                    = 30
net_write_timeout                   = 30
#****************************** myisam ******************************
skip_external_locking               = ON
key_buffer_size                     = 16M
bulk_insert_buffer_size             = 16M
concurrent_insert                   = ALWAYS
open_files_limit                    = 65000
table_open_cache                    = 16000
table_definition_cache              = 16000
#****************************** innodb ******************************
default_storage_engine              = InnoDB
default_tmp_storage_engine          = InnoDB
internal_tmp_disk_storage_engine    = InnoDB
innodb_data_home_dir                = /data/mysql
#innodb_log_group_home_dir          = /data/mysql/rlog
innodb_log_file_size                = 1024M
innodb_log_files_in_group           = 3
#innodb_undo_directory              = /data/mysql/ulog
innodb_undo_log_truncate            = on
innodb_max_undo_log_size            = 1024M
innodb_undo_tablespaces             = 0
innodb_flush_log_at_trx_commit      = 2
innodb_fast_shutdown                = 1
#innodb_flush_method                = O_DIRECT
innodb_io_capacity                  = 1000
innodb_io_capacity_max              = 4000
innodb_buffer_pool_size             = 4G
innodb_log_buffer_size              = 32M
innodb_autoinc_lock_mode            = 1
innodb_buffer_pool_load_at_startup  = ON
innodb_buffer_pool_dump_at_shutdown = ON
innodb_buffer_pool_dump_pct         = 15
innodb_max_dirty_pages_pct          = 85
innodb_lock_wait_timeout            = 10
#innodb_locks_unsafe_for_binlog     = 1
innodb_old_blocks_time              = 1000
innodb_open_files                   = 63000
innodb_page_cleaners                = 4
innodb_strict_mode                  = ON
innodb_thread_concurrency           = 24
innodb_sort_buffer_size             = 64M
innodb_print_all_deadlocks          = 1
innodb_rollback_on_timeout          = ON
#****************************** safe ******************************
ssl-ca = ${Deploy_path}/mysql/ca-pem/ca.pem
ssl-cert = ${Deploy_path}/mysql/ca-pem/server-cert.pem
ssl-key = ${Deploy_path}/mysql/ca-pem/server-key.pem
[client]
socket                              = /data/mysql/mysql.sock
EOF
sudo chown -R ${USER}.${USER} /etc/my.cnf

1.10 创建SSL证书

sudo mkdir -p ${Deploy_path}/mysql/ca-pem/
sudo ${Deploy_path}/mysql/bin/mysql_ssl_rsa_setup -d ${Deploy_path}/mysql/ca-pem/ --uid=mysql
sudo chown -R ${USER}.${USER} ${Deploy_path}/mysql/ca-pem/

sudo bash -c "cat >> /data/mysql/init_file.sql" <<EOF
set global sql_safe_updates=0;
set global sql_select_limit=50000;
EOF
sudo chown -R ${USER}.${USER} /data/mysql/init_file.sql
sudo chown -R ${USER}.${USER} /etc/init.d/mysqld

1.11 启动服务

/etc/init.d/mysqld start

1.12 修改初始密码

${Deploy_path}/mysql/bin/mysqladmin -uroot -p${mysql_passwd} password ')&09@zzy.com'

${Deploy_path}/mysql/bin/mysql -uroot -p')&09@zzy.com' -e "create database \`uusafe-core\`"
${Deploy_path}/mysql/bin/mysql -uroot -p')&09@zzy.com' -e "GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, ALTER, CREATE VIEW, RELOAD ON *.* TO 'root'@'%' IDENTIFIED BY ')&09@zzy.com' with grant option;"
${Deploy_path}/mysql/bin/mysql -uroot -p')&09@zzy.com' -e "GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, ALTER, CREATE VIEW, RELOAD ON *.* TO 'root'@'127.0.0.1' IDENTIFIED BY ')&09@zzy.com' with grant option;"
${Deploy_path}/mysql/bin/mysql -uroot -p')&09@zzy.com' uusafe-core < /opt/deploy_mos/Config_file/mysql/uusafe-core.sql 
${Deploy_path}/mysql/bin/mysql -uroot -p')&09@zzy.com' -e "flush privileges"

1.13 客户端环境变量

echo "export PATH=\$PATH:${Deploy_path}/mysql/bin" | sudo tee -a /etc/profile
source /etc/profile

2. 主从配置

调整主从时需要将应用程序停止服务。

2.1 修改数据库配置

vim /etc/my.cnf
#****************************** replication ******************************
server-id=1
log_bin=mysql-bin
# 不同步数据库
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
binlog-ignore-db=sys
# 只仅同步数据库
# binlog-do-db=zixuephp-db
# #mysql复制模式,三种:SBR(基于sql语句复制),RBR(基于行的复制),MBR(混合模式复制)
binlog_format=MIXED
#****************************** replication ******************************
server-id=2
log_bin=mysql-bin

2.2 在主库创建从库的复制用户

mysql> grant replication slave on *.* to 'rep'@'%' identified by '123456';
mysql> flush privileges;

2.3 查看主库状态

mysql> show master status;
+------------------+----------+--------------+-------------------------------------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB                                | Executed_Gtid_Set |
+------------------+----------+--------------+-------------------------------------------------+-------------------+
| mysql-bin.000001 |   495598 |              | mysql,information_schema,performance_schema,sys |                   |
+------------------+----------+--------------+-------------------------------------------------+-------------------+

2.4 备份主库数据

mysqldump -h192.168.1.1 -p'123' > all.sql

2.5 在从库导入备份的数据

mysql> source all.sql;

2.6 在从库设置复制条件

mysql> change master to master_host='192.168.0.124',master_user='slave',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=495598;
mysql> start slave;
mysql> reset slave all;
    # 可在出错情况下重置

2.7 查看从库是否同步主库

mysql> show slave status\G;

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

2.8 在主库查看连接信息

mysql> show processlist \G;
*************************** 1. row ***************************
     Id: 15
   User: slave
   Host: 192.168.0.122:56982
     db: NULL
Command: Binlog Dump
   Time: 116
  State: Master has sent all binlog to slave; waiting for more updates
   Info: NULL

2.9 验证主从同步

在主库创建库,创建表:

mysql> create database rep_test;
mysql> use rep_test;
mysql> create table tb_test (tb_id INT NOT NULL AUTO_INCREMENT, tb_title VARCHAR(100) NOT NULL, tb_author VARCHAR(40) NOT NULL, tb_date DATE, PRIMARY KEY ( tb_id ));

在从库进行查询:

mysql> show databases;
+--------------------+
| Database            |
+--------------------+
| rep_test              |
+--------------------+

mysql> use rep_test;
mysql> desc tb_test;
+-----------+--------------+------+-----+---------+----------------+
| Field     | Type         | Null | Key | Default | Extra          |
+-----------+--------------+------+-----+---------+----------------+
| tb_id     | int(11)      | NO   | PRI | NULL    | auto_increment |
| tb_title  | varchar(100) | NO   |     | NULL    |                |
| tb_author | varchar(40)  | NO   |     | NULL    |                |
| tb_date   | date         | YES  |     | NULL    |                |
+-----------+--------------+------+-----+---------+----------------+

2.10 其他调试语句

#查看错误
show warnning;
#查看主库状态
show master status \G;
#查看从库状态
show slave status \G;
#重置主记录信息
reset master;
#重置从记录信息
reset slave;
#停止始从
stop slave;
#开始从
start slave;
#清空从所有连接、信息记录
reset slave all;
#删除从
change master to master_host=' ';



文章评论

目录