linux安装mysql

一、安装mysql

以mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz版本为例,本人亲测有效:
1、下载安装包:
wget http://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz

2、解压至/usr/local/mysql目录:
tar -zxvf mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz -C /usr/local/mysql

3、在/usr/local/mysql目录新建data目录
cd /usr/local/mysql
mkdir -p data

4、查看是否有mysql用户组(groups),没有则添加
groupadd mysql #添加用户组
useradd -r -s /sbin/nologin -g mysql mysql -d /usr/local/mysql #新建msyql用户禁止登录shell

5、改变/usr/local/mysql目录的权限
chown -R mysql:mysql /usr/local/mysql

6、初始化mysql
./bin/mysql_install_db –user=mysql –basedir=/usr/local/mysql/ –datadir=/usr/local/mysql/data/

会有提示:
[root@iZwz95rn6xcyrijlpfhyjlZ mysql]# ./bin/mysql_install_db –user=mysql –basedir=/usr/local/mysql/ –datadir=/usr/local/mysql/data/
2018-06-11 23:13:16 [WARNING] mysql_install_db is deprecated. Please consider switching to mysqld –initialize
2018-06-11 23:13:22 [WARNING] The bootstrap log isn’t empty:
2018-06-11 23:13:22 [WARNING] 2018-06-11T15:13:16.782882Z 0 [Warning] –bootstrap is deprecated. Please consider using –initialize instead

或者也可以使用此命令:

 bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/

7、看下/etc/my.cnf文件是否生成
生成内容:

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

如果没有生成,则复制:
cp -a ./support-files/my-default.cnf /etc/my.cnf #会有一个选择是否覆盖原有文件,直接按 y回车选择是就可以
my-default.cnf文件内容如下:

# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html
# *** DO NOT EDIT THIS FILE. It's a template which will be copied to the
# *** default location during install, and will be replaced if you
# *** upgrade to a newer version of MySQL.

[mysqld]

# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M

# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin

# These are commonly set, remove the # and set as required.
# basedir = .....
# datadir = .....
# port = .....
# server_id = .....
# socket = .....

# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

如果support-files/目录下没有my-default.cnf文件,则自己手动编辑一个/etc/my.cnf文件,内容则为上面生成的内容即可

8、把mysql放到本地服务中
cp -a support-files/mysql.server /etc/init.d/mysqld

9、编辑/etc/my.cnf,修改basedir、datadir对应的路径
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
socket = /tmp/mysql.sock (不配置也可以,默认生成的)

10、启动mysql服务:
service mysqld start

11、启动成功之后,查看mysql服务:
ps -ef | grep mysql –color
显示如下:

[root@iZwz95rn6xcyrijlpfhyjlZ mysql]# ps -ef|grep mysql
root      7056     1  0 23:27 pts/0    00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/data/iZwz95rn6xcyrijlpfhyjlZ.pid
mysql     7199  7056  0 23:27 pts/0    00:00:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/usr/local/mysql/data/iZwz95rn6xcyrijlpfhyjlZ.err --pid-file=/usr/local/mysql/data/iZwz95rn6xcyrijlpfhyjlZ.pid --port=3306

可以看到mysql服务启动成功

12、查看mysql初始化密码:
cat /root/.mysql_secret

[root@iZwz95rn6xcyrijlpfhyjlZ mysql]# cat /root/.mysql_secret 
# Password set for user 'root@localhost' at 2018-06-11 23:13:16 
tp/

13、连接mysql数据库(我是在/usr/local/mysql目录下做的如下命令):
bin/mysql -u root -p
然后粘贴刚刚复制的密码,连接成功

14、修改密码:
set password for ‘root’@localhost=password(‘123456’);

此时此刻,mysql安装完成

接下来做mysql的远程登录访问设置:

二、远程连接mysql

1、连接mysql
bin/mysql -uroot -p

2、连接好之后,查看所有数据库
show databases;

3、使用mysql数据库
use mysql

4、查看mysql下user的权限:
mysql> select user, host from user;
+———–+———–+
| user | host |
+———–+———–+
| mysql.sys | localhost |
| root | localhost |
+———–+———–+
2 rows in set (0.00 sec)

我们发现root用户只有localhost访问权限,则需要修改远程权限

5、修改root用户的远程访问权限:
mysql> update user set host=’%’ where user = ‘root’;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
%表示所有服务器都可以进行连接服务器

6、刷新权限:
flush privileges;

7、使用mysql连接工具navicat连接:
linux安装mysql_第1张图片

我们输入服务器ip地址及用户名密码后看到数据库连接成功

那么,我们就搞定咯~~

如果远程连接还连不上,那就考虑对应服务器的3306端口是否开放,一般买的云服务器,都有对应的安全规则设置的,把3306端口加进去开放就好啦!!

三、mysql环境变量设置:

把mysql设置到环境变量中,则任意位置都可以访问mysql命令,不需要到安装的bin目录去执行:
设置如下:

export PATH=/usr/local/mysql/bin/:$PATH

/usr/local/mysql/bin/为安装mysql的bin目录,执行之后,我们在任意位置就可以访问mysql啦:
比如在soft目录下访问:

[root@iZwz95rn6xcyrijlpfhyjlZ soft]# mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.7.17 MySQL Community Server (GPL)

你可能感兴趣的:(linux安装mysql)