yum -y install autoconf libaio bison ncurses-devel
groupadd mysql
useradd -g mysql -s /sbin/nologin mysql
mkdir -p /soft/server/mysql
tar -zxvf mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz -C /soft/server/
mv mysql-5.7.21-linux-glibc2.12-x86_64 mysql
mkdir -p /soft/log/mysql
mkdir -p /soft/server/mysql/data
chown -R mysql:mysql /soft/server/mysql
chown -R mysql:mysql /soft/log/mysql
[client]
port = 3306
socket = /soft/server/mysql/mysql.sock
[mysqld]
character_set_server=utf8
init_connect='SET NAMES utf8'
basedir=/soft/server/mysql
datadir=/soft/server/mysql/data
socket=/soft/server/mysql/mysql.sock
log-error=/soft/log/mysql/mysqld.log
pid-file=/soft/server/mysql/mysqld.pid
cd /soft/server/mysql/bin
/soft/server/mysql/bin/mysqld --initialize --user=mysql --basedir=/soft/server/mysql --datadir=/soft/server/mysql/data --lc_messages_dir=/soft/server/mysql/share --lc_messages=en_US
vim /lib/systemd/system/mysql.service
[Unit]
Description=mysql
After=network.target remote-fs.target nss-lookup.target
[Service]
Type=forking
ExecStart=/soft/server/mysql/support-files/mysql.server start
ExecReload=/soft/server/mysql/support-files/mysql.server restart
ExecStop=/soft/server/mysql/support-files/mysql.server stop
PrivateTmp=true
[Install]
WantedBy=multi-user.target
Description:描述服务
After: 描述服务类别
[Service] 服务运行参数的设置
Type=forking 是后台运行的形式
ExecStart 为服务的具体运行命令
ExecReload 为重启命令
ExecStop为 停止命令
PrivateTmp=True 表示给服务分配独立的临时空间
注意:[Service]的启动、重启、停止命令全部要求使用绝对路径
[Install]运行级别下服务安装的相关设置,可设置为多用户,即系统运行级别为3
echo 'PATH=$PATH':/sort/server/mysql/bin >> /etc/profile
source /etc/profile
systemctl daemon-reload
systemctl start mysql
systemctl enable mysql
cat -n /sort/log/mysql/mysqld.log | grep 'root@localhost'
出现后面就是mysql的初始密码。
mysql -u root -p 初始密码登陆进去后,需要修改初始密码,mysql才可以正常连接。
修改mysql密码为为123456 :ALTER USER USER() IDENTIFIED BY '123456';
当我们使用数据库连接工具连接mysql的时候,发现连接失败!!!but我们在linux上使用命令行可以登陆到mysql数据库,检查了以下防火墙也关闭了,这个原因是mysql开启了只能本地连接的原因。所以要修改mysql默认本地连接的限制,查看可以连接mysql的用户:
SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;
这里演示给root用户授予权限,其他用户授权方式可以参考一下:以下方式
CREATE USER 'root'@'%' IDENTIFIED BY '123456';
GRANT ALL ON *.* TO 'root'@'%';
flush privileges;
执行后的效果图如下:
此时内网就可以连接上mysql啦!
此外需要注意 linux环境下的mysql默认大小写敏感的问题,当我们部署好mysql时候,将自己平时研究的代码部署到服务器,连接mysql时候发现报以下错误:
org.springframework.jdbc.BadSqlGrammarException:
Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:
Table 'test.T_USER_LOGIN' doesn't exist
The error may exist in class path resource [mybatis/LoginMapper.xml]
发现执行sql时候报了表名不存在,这是由于linux的mysql大小写敏感的原因,所以只需修改/etc/my.cnf 配置文件,加上lower_case_table_names=1
如下图所示:
特别说明:lower_case_table_names参数详解:其中 0:区分大小写,1:不区分大小写
。
配置好以后只需重启mysql服务即可。