与源码版本安装过程基本一致,除了编译环节,本文只谈release版,即含有bin文件版本
目标主机系统:CentOS 6.8
目录:/home/saojie/MysqL-5.7.18
下载
Linux Generic
地址:https://dev.MysqL.com/downloads/MysqL/
解压
tar zxvf MysqL-5.7.18-linux-glibc2.5-x86_64.tar.gz
mv MysqL-5.7.18-linux-glibc2.5-x86_64 MysqL-5.7.18
安装
写配置文件
将my.cnf放在MysqL-5.7.18目录下
[MysqLd]
basedir = /home/saojie/MysqL-5.7.18
datadir = /home/saojie/MysqL-5.7.18/data
log_error = /home/saojie/MysqL-5.7.18/data/MysqL_error.log
port = 33306 #端口避免冲突
socket = /home/saojie/MysqL-5.7.18/MysqL.sock
general_log = on
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[MysqL]
socket = /home/saojie/MysqL-5.7.18/MysqL.sock
初始化
bin/MysqLd --defaults-file=/home/saojie/MysqL-5.7.18/my.cnf --initialize --user=saojie --basedir=/home/saojie/MysqL-5.7.18/ --datadir=/home/saojie/MysqL-5.7.18/data
启动
第一次启动加socket避免连接到别人的MysqL Server,且因为root默认是没有远程访问权限,刚开始root无法通过指定IP和端口连接
bin/MysqLd --defaults-file=/home/saojie/MysqL-5.7.18/my.cnf &
MysqL -uroot -p --socket=/home/saojie/MysqL-5.7.18/MysqL.sock #不加socket可能会连接到别的MysqL Server
bin/MysqLadmin -uroot -proot --socket=/home/saojie/MysqL-5.7.18/MysqL.sock shutdown
或
bin/MysqLadmin -hxxx -Pxxx -uroot -proot shutdown
其他问题
JDBC连接缓慢
在配置文件[MysqLd]下加上skip-name-resolve再重启,跳过DNS查询
在[MysqLd]下指定log_error地址
便捷脚本
#!/bin/bash
function client(){
bin/MysqL --defaults-extra-file=/home/saojie/MysqL-5.7.18/my.cnf
}
function server(){
bin/MysqLd --defaults-extra-file=/home/saojie/MysqL-5.7.18/my.cnf &
}
function stop(){
bin/MysqLadmin -uroot -p --socket=/home/saojie/MysqL-5.7.18/MysqL.sock shutdown
}
function pid(){
ret=$(ps -ef |grep MysqLd | awk '{print $2}')
echo $ret
}
if [ $# = 1 ]; then $1; else server; fi