欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

centos编译安装mysql 5.6及安装多个mysql实例详解

程序员文章站 2023-12-04 23:01:58
--1.为mysql新建组和用户 # useradd -m -s /sbin/nologin mysql --2.安装需要的库,编译器 # yum...

--1.为mysql新建组和用户

# useradd -m -s /sbin/nologin mysql

--2.安装需要的库,编译器

# yum install ncurses-devel openssl-devel cmake -y

--3.解压

# tar zxvf mysql-5.6.35.tar.gz
# cd mysql-5.6.35

--4.编译安装

# cmake \
-dcmake_install_prefix=/usr/local/mysql \
-dmysql_datadir=/usr/local/mysql/data \
-dsysconfdir=/etc \
-dwith_myisam_storage_engine=1 \
-dwith_innobase_storage_engine=1 \
-dwith_memory_storage_engine=1 \
-dwith_readline=1 \
-dmysql_tcp_port=3306 \
-denabled_local_infile=1 \
-dwith_partition_storage_engine=1 \
-dextra_charsets=all \
-ddefault_charset=utf8 \
-ddefault_collation=utf8_general_ci \
-dmysql_user=mysql \
-dwith_debug=0 \
-dwith_ssl=system
# make
# make install

--5.拷贝模版,作为配置文件

# cp support-files/my-default.cnf /etc/my.cnf

--6.设置mysql权限

# chown -r mysql.mysql /usr/local/mysql/

--7.初始化mysql数据库

# /usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql
# chown -r root /usr/local/mysql/
# chown -r mysql /usr/local/mysql/data/


--8.设置mysql开机自启动

# cp support-files/mysql.server /etc/init.d/mysqld
# chmod +x /etc/init.d/mysqld
# chkconfig mysqld on

--9.测试并运行mysql

#service mysqld start

--10.修改mysql管理员密码

#/usr/local/mysql/bin/mysqladmin -u root password '要设置的密码'

--11.使用用户登录mysql

# /usr/local/mysql/bin/mysql -u root -p

--12.加入环境变量

# echo 'path=/usr/local/mysql/bin/:$path' >>/etc/profile
# source /etc/profile

            centos 6.5最小化编译安装mysql 5.5.35配置多实例

1、关闭防火墙

1234567 [root@mysql ~]# service iptables stop
iptables: setting chains to policy accept: filter   [ ok ]
iptables: flushing firewall rules:       [ ok ]
iptables: unloading modules:        [ ok ]
[root@mysql ~]# chkconfig iptables off
[root@mysql ~]# chkconfig iptables --list
iptables  0:off 1:off 2:off 3:off 4:off 5:off 6:off

2、关闭selinux

12 [root@mysql ~]# setenforce 0
[root@mysql ~]# vim /etc/sysconfig/selinux

修改下面这一行;

selinux=disabled
12 [root@mysql ~]# getenforce 
permissive

3、安装mysql依赖包及编译工具;

1234 [root@mysql ~]# yum install libaio-devel -y
[root@mysql ~]# yum install -y ncurses-devel
[root@mysql ~]# yum install -y gcc gcc-c++ 
[root@mysql ~]# yum install -y cmake

4、安装前准备;

4.1、安装路径:

1 [root@mysql ~]# mkdir /usr/local/mysql 

4.2、数据库路径:

1 [root@mysql ~]# mkdir /data/mysql -p 

4.3、创建用户和用户组

12 [root@mysql ~]# groupadd mysql
[root@mysql ~]# useradd -r -g mysql -s /bin/false mysql

4.4、赋予数据存放目录权限

1 [root@mysql ~]# chown mysql:mysql -r /data/mysql 

5、编译安装mysql 5.5.35

1234567 [root@mysql ~]# yum install -y lrzsz
root@mysql ~]# mkdir /package
[root@mysql ~]# cd /package/
[root@mysql package]# tar xf mysql-5.5.32.tar.gz 
[root@mysql package]# cd mysql-5.5.32
[root@mysql mysql-5.5.32]# cmake . -dcmake_install_prefix=/usr/local/mysql -dmysql_unix_addr=/data/mysql/mysql.sock -ddefault_charset=utf8 -ddefault_collation=utf8_general_ci -dwith_extra_charsets:string=utf8,gbk -dwith_innobase_storage_engine=1 -dwith_readline=1 -denabled_local_infile=1 -dmysql_datadir=/data/mysql/ -dmysql_user=mysql -dmysql_tcp_port=3306
[root@mysql mysql-5.5.32]# make && make install

6、创建多实例数据库文件存放位置;

12345678 [root@mysql ~]# mkdir -p /data/{3306,3307}/data
[root@mysql ~]# tree /data
/data
|-- 3306
|  `-- data
`-- 3307
  `-- data
4 directories, 0 files 

7、修改配置文件(my.cnf)如下行,分别放入3306、3307目录当中;

123456789 [root@mysql 3306]# vim my.cnf 
[client]
port      = 3306
socket     = /data/3306/mysql.sock
[mysqld]
port      = 3306
socket     = /data/3306/mysql.sock
datadir     = /data/3306
server-id    = 3306

8、初始化数据库;

注意:初始化数据库时需要指定不同的数据目录

123 [root@mysql mysql-5.5.32]# cd /usr/local/mysql/
[root@mysql mysql]# scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/data/3306
[root@mysql mysql]# scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/data/3307

9、启动多实例,启动脚本可以加入到开机自启动文件中。

12 [root@mysql mysql]# /usr/local/mysql/bin/mysqld_safe --defaults-file=/data/3306/my.cnf 2>&1 >/dev/null &  
[root@mysql mysql]# /usr/local/mysql/bin/mysqld_safe --defaults-file=/data/3307/my.cnf 2>&1 >/dev/null &

9.1、查看端口;

12345678 [root@mysql mysql]# netstat -tunlp
active internet connections (only servers)
proto recv-q send-q local address        foreign address       state    pid/program name  
tcp    0   0 0.0.0.0:3307        0.0.0.0:*          listen   11621/mysqld    
tcp    0   0 0.0.0.0:22         0.0.0.0:*          listen   1266/sshd      
tcp    0   0 0.0.0.0:3306        0.0.0.0:*          listen   11338/mysqld    
tcp    0   0 :::22            :::*            listen   1266/sshd      
udp    0   0 0.0.0.0:68         0.0.0.0:*                969/dhclient

10、登录多实例数据库

12 [root@mysql mysql]# /usr/local/mysql/bin/mysql -u root -p -p 3306 -s /data/3306/mysql.sock
[root@mysql mysql]# /usr/local/mysql/bin/mysql -u root -p -p 3307 -s /data/3307/mysql.sock

11、关闭mysql多实例方式

12 [root@mysql mysql]# /usr/local/mysql/bin/mysqladmin -u root -p -p 3306 -s /data/3306/mysql.sock shutdown  
[root@mysql mysql]# /usr/local/mysql/bin/mysqladmin -u root -p -p 3307 -s /data/3307/mysql.sock shutdown
cat ​/etc/my.cnf 
[mysqld1]
datadir=/data/mysql
socket=/tmp/mysql.sock
user=mysql
symbolic-links=0
skip-name-resolve
server-id=1221
max_connections = 2000
binlog-ignore-db=mysql
binlog-ignore-db=test
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
innodb_buffer_pool_size = 2g
innodb_additional_mem_pool=16m
innodb_log_file_size=256m
innodb_flush_log_at_trx_commit=2
character_set_server=utf8
collation_server = utf8_general_ci
replicate_ignore_db = mysql
slave-skip-errors=all
relay_log=/data/mysql/
[mysqld2]
port=3307
server-id=1222
log-error=/tmp/mysqld2.log
datadir=/data/mysql_live
socket=/tmp/mysql2.sock
user=mysql
symbolic-links=0
skip-name-resolve
character_set_server=utf8
collation_server = utf8_general_ci
max-connections=500
default-storage-engine=innodb
innodb_file_per_table
log-bin=mysql-bin
relay-log-info-repository=table
master-info-repository=table
expire_logs_days=10
binlog_format=row
transaction-isolation=read-committed
binlog-ignore-db=mysql
binlog-ignore-db=test
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
slow_query_log=true
slow_query_log_file=/tmp/mysqld_slow_query2.log
long_query_time=3
replicate_ignore_db = mysql
slave-skip-errors=all
[mysqld3]
server-id=1223
port=3308
log-error=/tmp/mysqld3.log
datadir=/data/mysql
socket=/tmp/mysql3.sock
user=mysql
symbolic-links=0
skip-name-resolve
character_set_server=utf8
collation_server = utf8_general_ci
max-connections=500
default-storage-engine=innodb
innodb_file_per_table
​log-bin=mysql-bin
relay-log-info-repository=table
master-info-repository=table
expire_logs_days=10
binlog_format=row
transaction-isolation=read-committed
binlog-ignore-db=mysql
binlog-ignore-db=test
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
slow_query_log=true
slow_query_log_file=/tmp/mysqld_slow_query3.log
long_query_time=3
replicate_ignore_db = mysql
slave-skip-errors=all
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/data/mysql/mysqld.pid