CentOS7 安装 MySQL

1.下载mysq的repo源
  wget http://repo.mysql.com/mysql-community-release-e17-5.noarch.rpm

2.安装mysql-community-release-e17-5.noarch.rpm包
  sudo rmp -ivh mysql-community-release-e17-5.noarch.rpm

安装这两个包后,会获得两个MySQL的yum repo源:
  /etc/yum.repos.d/mysql-community.repo
  /etc/yum.repos.d/mysql-community-source.repo

3.安装MySQL

  sudo yum install mysql-server mysql-client libmysqlclient-dev mysql-devel 

  MySQL-python(与上面那一行连着写)

如果上面遇到问题:
  看下服务开没 systemctl status mysqld

4.初始化:
  mysql_install_db

5.设置密码
  方式一(SET PASSWORD 命令):
    mysql -u root
    SET PASSWORD FOR 'root'@'localhost'=PASSWORD('新密码');

  方式二(使用mysqladmin):
    mysqladmin -u root password '新密码'
    如果root已经设置过密码,采用以下方法:
    mysqladmin -u root password 旧密码 '新密码'

  方式三(使用update直接编辑user表):
    mysql -u root
    use mysql
    UPDATE user SET PASSWORD = PASSWORD('新密码') WHERE user = 'root';

  忘记密码:
    mysql_safe --skip-grant-tables
    mysql -u root myql
    UPDATE user SET PASSWORD = PASSWORD('新密码') WHERE user = 'root';
    FLUSH PRIVILEGES;

设置utf-8编码:
  在 vi/etc/my.cnf:
    # 在文件中[mysqld]下面增加一行:
    character_set_server = utf8
  # 重启生效
    systemctl restart mysqld

重启命令:

  server mysqld restart

MySQL服务:

  1.启动命令:

    /bin/systemctl start mysqld.service

  2.关闭命令

    /bin/systemctl stop mysqld.service

  3.重启命令

    /bin/systemctl restart mysqld.service

  4.查看状态

    /bin/systemctl status mysqld.service

查看系统配置文件:

  cat etc/my.cnf

 

报错:

mysql Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

错误原因:/var/lib/mysql目录中socket文件不存在。
连接mysql服务器有两种方式:tcp连接,通过socket文件连接。通过socket文件,启动mysql服务,mysql服务会自动生成一个sock文件,生成的sock文件默认放在 --datadir=/var/lib/mysql,mysql默认从/var/lib/mysql目录读取sock文件。

解决办法:
1、看看/var/lib/mysql/mysql 有没有mysql.sock文件
2、没有mysql.sock,重启mysql服务,看看有没有。
3、没有的话,ps aux|grep mysql|grep -v 'grep' 查看mysql服务生成的sock在哪个目录,看看这个目录有没有。
4、如果mysql服务生成在其他目录,解决办法有:
方法一、修改mysql服务生成的目录,在my.cnf 中[mysqld] socket
方法二、mysql从/var/lib/mysql/读取sock文件,建立一个软连接,或者copy过来
方法三、修改mysql读取的目录,在my.cnf 中[mysql] socket
方法四、启动指定socket,mysql -uroot -p123456 --socket='/var/lib/mysql/mysql.sock'

注意:
1、通过socket,只能在本地机器上连接。
2、使用-hlocalhost就是经过socket,不经过网络,通过netstat 看不到tcp连接,可以认为mysql与mysql.sock文件交互,向里面写数据,从里面读取数据。
3、使用-h127.0.0.1就是经过tcp,通过netstat 可以看到连接。

 

启动mysql 报错:

ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2)

1、先查看 /etc/rc.d/init.d/mysqld status 看看m y s q l 是否已经启动.
另外看看是不是权限问题.

2、确定你的mysql.sock是不是在那个位置,
mysql -u 你的mysql用户名 -p -S /var/lib/mysql/mysql.sock

3、试试:service mysqld start

4、如果是权限问题,则先改变权限 #chown -R mysql:mysql /var/lib/mysql

[root@localhost ~]# /etc/init.d/mysqld start
启动 MySQL: [ 确定 ]
[root@localhost ~]# mysql -uroot -p

 

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
   原因是,/var/lib/mysql 的访问权限问题。

shell> chown -R mysql:mysql /var/lib/mysql

接着启动服务器

shell> /etc/init.d/mysql start

服务器正常启动后察看 /var/lib/mysql 自动生成mysql.sock文件。

 

 

 

chown -R mysql:mysql ./及chown详解

当我们在不通过yum(CentOS<redhat>)、apt-get(Ubuntu<debian>)来安装MySQL的时候,通常执行以下命令来改变目录的拥有者:

[root@localhost ~]# chown -R  mysql:mysql ./
那?这两个mysql谁是用户名谁是用户组呢?见chown详解

     chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID;组可以是组名或者组ID;文件是以空格分开的要改变权限的文件列表,支持通配符。系统管理员经常使用chown命令,在将文件拷贝到另一个用户的名录下之后,让用户拥有使用该文件的权限。 

  1.命令格式:

    chown [选项]... [所有者][:[组]] 文件...

  2.命令功能:

    通过chown改变文件的拥有者和群组。在更改文件的所有者或所属群组时,可以使用用户名称和用户识别码设置。普通用户不能将自己的文件改变成其他的拥有者。其操作权限一般为管理员。

  3.命令参数:

  必要参数:

    -c 显示更改的部分的信息

    -f 忽略错误信息

    -h 修复符号链接

    -R 处理指定目录以及其子目录下的所有文件

    -v 显示详细的处理信息

    -deference 作用于符号链接的指向,而不是链接文件本身

  选择参数:

    --reference=<目录或文件> 把指定的目录/文件作为参考,把操作的文件/目录设置成参考文件/目录相同拥有者和群组

    --from=<当前用户:当前群组> 只有当前用户和群组跟指定的用户和群组相同时才进行改变

    --help 显示帮助信息

    --version 显示版本信息

 

posted @ 2018-10-26 13:37  Coca-Mirinda  阅读(930)  评论(0编辑  收藏  举报