公众号

Linux安装mysql

1、下载安装包“mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz”

下载地址:http://dev.mysql.com/downloads/mysql/5.6.html#downloads  

安装依赖

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
yum -y install perl perl-devel autoconf libaio
2、把下载的安装包移动到/usr/local/下。
3、解压
tar zxvf mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz
4、复制解压后的mysql目录到系统的本地软件目录
cp mysql-5.6.33-linux-glibc2.5-x86_64 /usr/local/mysql -r
5、添加系统mysql组和mysql用户
groupadd mysql
useradd -r -g mysql -s /bin/false mysql
注意:Because the user is required only for ownership purposes, not login purposes, the useradd command uses the -r and -s /bin/false options to create a user that does not have login permissions to your server host. Omit these options if your useradd does not support them.
6、进入安装mysql软件目录,修改目录拥有者为mysql用户
cd mysql/
chown -R mysql:mysql ./
7、安装数据库,此处可能出现错误。
./scripts/mysql_install_db --user=mysql
FATAL ERROR: please install the following Perl modules before executing scripts/mysql_install_db:
Data::Dumper

#解决方法:

1
2
3
4
5
6
7
yum install -y perl-Data-Dumper
8、修改当前目录拥有者为root用户
chown -R root:root ./
9、修改当前data目录拥有者为mysql用户
chown -R mysql:mysql data

============== 到此数据库安装完毕 =============

添加mysql服务开机自启动

添加开机启动,把启动脚本放到开机初始化目录。

1
2
cp support-files/mysql.server /etc/init.d/mysql

赋予可执行权限

1
chmod +x /etc/init.d/mysql

添加服务

1
chkconfig --add mysql

#加入环境变量,编辑 /etc/profile,这样可以在任何地方用mysql命令了

1
export PATH=$PATH:/usr/local/mysql//bin source /etc/profile

显示服务列表

1
chkconfig --list

如果看到mysql的服务,并且3,4,5都是on的话则成功,如果是off,则执行

1
chkconfig --level 345 mysql on

启动mysql服务

#创建缺少的文件夹

1
2
mkdir /var/log/mariadb
service mysql start

正常提示信息:Starting MySQL. SUCCESS!

把mysql客户端放到默认路径

1
ln -s /usr/local/mysql/bin/mysql /usr/local/bin/mysql

注意:建议使用软链过去,不要直接包文件复制,便于系统安装多个版本的mysql

=================== 这是分割线 ==================

通过使用 mysql -uroot -p 连接数据库(默认数据库的root用户没有密码,这个需要设置一个密码)。

错误信息:ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2)

解决方法:打开/etc/my.cnf,看看里面配置的socket位置是什么目录。“socket=/var/lib/mysql/mysql.sock”

路径和“/tmp/mysql.sock”不一致。建立一个软连接:ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock

到这里任务算是完成了。之后就可以创建数据库用户,然后使用数据库了。

有其他错误看本博客有没有其他文章关于解决mysql安装问题的

远程连接错误(博客以一篇mysql的文章专门解决这个问题)

错误

  5.1 sqlyog连接时,报1130错误,是由于没有给远程连接的用户权限问题

    解决1:更改 ‘mysql’数据库‘user’表‘host’项,从‘localhost’改成‘%’。

use mysql;
select ‘host’ from user where user=’root’;
update user set host = ‘%’ where user =’root’;
flush privileges;
    解决2:直接授权

1
      GRANT ALL PRIVILEGES ON *.* TO ‘root’@'%’ IDENTIFIED BY ‘youpassword’ WITH GRANT OPTION;

  5.2 安装时的一些错误

1
2
3
4
5
    -bash: ./scripts/mysql_install_db: /usr/bin/perl: bad interpreter: 没有那个文件或目录
    解决: yum -y install perl perl-devel
    Installing MySQL system tables..../bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
    解决:yum -y install libaio-devel

6、其他

  6.1 配置环境变量

1
2
3
    vi + /etc/profile
    export PATH=....:/usr/local/mysql/bin

最后想说:Fork me on GitHub 欢迎 Star

🙈坚持原创技术分享,您的支持将鼓励我继续创作🙈