MySQL 5.6x版本安装

MySQL 安装

MySQL5.6版本安装官网手册:https://dev.mysql.com/doc/refman/5.6/en/source-installation.html

5.6 与 5.7 版本的安装有所不同

常用配置项参数:

DCMAKE_INSTALL_PREFIX安装到的软件目录
-DMYSQL_DATADIR数据文件存储的路径
-DSYSCONFDIR配置文件路径 (my.cnf)
-DENABLED_LOCAL_INFILE=1使用localmysql客户端的配置
-DWITH_PARTITION_STORAGE_ENGINE使mysql支持分表
-DEXTRA_CHARSETS安装支持的字符集
-DDEFAULT_CHARSET默认字符集使用 这里配置为utf8mb4
-DDEFAULT_COLLATION连接字符集
-DWITH_SSL开启mysql的ssl使用
-DWITH_MYISAM_STORAGE_ENGINE=1支持MyIASM引擎
DWITH_INNOBASE_STORAGE_ENGINE=1支持InnoDB引擎
DWITH_MEMORY_STORAGE_ENGINE=1支持Memory引擎
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock连接数据库socket路径
-DMYSQL_TCP_PORT=3306端口
-DENABLED_LOCAL_INFILE=1允许从本地导入数据

初始化参数:

–basedir安装到的软件目录
–datadir数据文件存储路径
–usermysql使用的用户

MySQL具体安装:

安装目录/usr/local/mysql
数据目录/usr/local/mysql/data
配置文件/etc/my.cf
套接字默认是在/tmp/mysql/sock,如果要修改存储位置可以添加,不修改不用添加

在这里插入图片描述

使用脚本安装MySQL并初始化:

  • MySQL在安全配置的时候设置密码
#!/bin/bash
read -p "请输入需要安装的MySQL源码包,如mysql-5.6.33:" mysql_source

mkdir ./$mysql_source && tar xf $mysql_source.tar.gz -C ./$mysql_source --strip-components 1

if ! (id mysql &> /dev/null);then
   useradd -r -s /sbin/nologin -M mysql
fi
[ -f /etc/my.cnf ] && mv /etc/my.cnf /etc/my.cnf.bak



# 安装依赖
 yum -y install cmake bison-devel ncurses-devel libaio-devel

# 配置+编译安装
cd $mysql_source/
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DSYSCONFDIR=/etc \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8mb4 \
-DDEFAULT_COLLATION=utf8mb4_general_ci \
-DWITH_SSL=bundled
make && make install

# 将MySQL的配置文件拷贝一份到/etc目录下
if [ -d /usr/local/mysql ];then
   cd /usr/local/mysql
   cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf

# 授权并初始化MySQL
   chown -R mysql:mysql /usr/local/mysql
   /usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql
fi
#安全配置服务、自启动和环境变量
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
echo 'export PATH=$PATH:/usr/local/mysql/bin' >> /etc/profile
source /etc/profile
service mysqld start
chkconfig --add mysqld
chkconfig mysqld on

# 对MySQL进行安全配置,删除匿名用户,利用expect自动交互套件执行

if ! (rpm -q expect &> /dev/null);then
yum -y install expect
fi
/usr/bin/expect <<-EOF
set timeout 20
spawn mysql_secure_installation
expect {
 "enter for none" { send "\r"; exp_continue }
 " password:" { send "123\r"; exp_continue  }
 "Y/n"  { send "Y\r"; exp_continue }
 "Cleaning up" { send "\r"}
}
expect eof
EOF
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值