Linux下安装二进制mysql

时间:2021-07-05 04:49:59

重新装了一下mysql,好多过程忘了,参照各种资源,记录一下操作过程,我这里使用的是二进制包,但实际上源码包进行自己编译才是性能最靠谱的……我这里使用的是5.7.21

1.下载二进制包
下载的时候注意根据自己系统版本进行选择,我这里选择的是
Linux下安装二进制mysql
然后选择最后的tar打包文件下载然后搞到虚拟机进行解打包、解压缩命令(解压缩只针对mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz文件)
有的虚拟机自带了Mariadb数据库就把他卸载了吧

# 查看是否有该数据库
rpm -qa|grep mariadb
# 有的话就卸载,就是上面查找到的结果
rpm -e --nodeps mariadb-libs...
# 删除my.cnf文件
rm /etc/my.cnf

2.配置mysql

# 创建mysql的用户组
groupadd mysql

# 在mysql用户组内添加一个用户名为mysql的用户(第一个mysql是组名,后者是用户名)
useradd -g mysql mysql

# 设置密码,可以直接设置为111111
passwd mysql

# 指定mysql用户组对mysql的权限(我解压后将文件夹重命名为mysql了)
chown -R mysql /usr/mysql/
chgrp -R mysql /usr/mysql/

# 创建data文件夹并赋予mysql用户组下的mysql用户权限
mkdir data
chown -R mysql:mysql data

# 创建配置文件
vim /etc/my.cnf
# 追加如下内容:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
skip-name-resolve
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=/usr/mysql
# 设置mysql数据库的数据的存放目录
datadir=/usr/mysql/data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M

# 安装
bin/mysql_install_db --user=mysql --basedir=/usr/mysql/ --datadir=/usr/mysql/data/

# 添加服务并授权
cp ./support-files/mysql.server /etc/init.d/mysql
chown 777 /etc/my.cnf
chmod +x /etc/init.d/mysql

# 设置环境变量
vim /etc/profile
# 追加mysql的环境变量
PATH=$PATH:$JAVA_HOME/bin:$HADOOP_HOME/bin:$HADOOP_HOME/sbin:/usr/mysql/bin
export PATH
# 刷新
source /etc/profile


# 启动mysql服务
/etc/init.d/mysql start

# 获取初始密码
cat /root/.mysql_secret

# 设置当前登录mysql的用户密码
mysql -uroot -p

mysql> set PASSWORD = PASSWORD('111111');
mysql> flush privileges;

3. 设置开机自启(可选)

chkconfig --level 35 mysqld on
chkconfig --list mysql
chmod +x /etc/rc.d/init.d/mysql
chkconfig --add mysql
chkconfig --list mysql
service mysql status

4.开启远程连接(可选)

# 允许root用户名(指定root用户名)使用任意ip登录(%代表任意IP可以修改为指定IP),
# 远程登录密码为“password”(可以自行修改),这里实际上是创建了一个远程登录用户
grant all privileges on *.* to 'root'@'%' identified by 'password';

# 使上述权限生效
flush privileges;

# 查看配置是否生效,
use mysql;
select user,host from user;

会有添加的root用户和允许登录的IP为%
Linux下安装二进制mysql
然后

# 重启服务
/etc/init.d/mysql restart

即可,注意防火墙一定要事前关闭,或者不关闭但要开放mysql的3306端口才可以!然后直接在DOS窗口下来进行远程登录测试:

# 远程登录
mysql -u hadoop -h 192.168.89.131 -p

其实所有关于用户的操作都是基于mysql数据库中的user表,可以直接修改这张表进行用户的增、删、改、查