遇到的问题
Navicat 链接虚拟机Mysql 报错:2003-Can't connect to Mysql server on 'xxx' (10060 "Unknown error")
在MySQL登录时出现Access denied for user 'root'@'localhost' (using password: YES) 拒绝访问,并可修改MySQL密码
解决telnet提示Escape character is ‘^]’.
mysql安装的一些问题记录
安装
1:卸载旧版本
使用下面的命令检查是否安装有MySQL Server
rpm -qa | grep mysql
有的话通过下面的命令来卸载掉
rpm -e mysql //普通删除模式
rpm -e --nodeps mysql // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除
2:安装MySQL
安装编译代码需要的包
yum install cmake make -y
yum install gcc gcc-c++ autoconf bison automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel* -y
下载MySQL 5.6.25
wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.25.tar.gz
tar xvf mysql-5.6.25.tar.gz
cd mysql-5.6.25
编译安装 --注意复制下面的命令可能有中文乱码--
cmake -DCMAKE_INSTALL_PREFIX=/app/mysql -DMYSQL_UNIX_ADDR=/app/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/app/mysql/data -DMYSQL_USER=mysql
make && make install
编译的参数可以参考
http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html
整个过程需要30分钟左右
3:配置MySQL
>设置权限
使用下面的命令查看是否有mysql用户及用户组
cat /etc/passwd | grep mysql // 查看用户列表
cat /etc/group |grep mysql // 查看用户组列表
如果没有就创建
groupadd mysql
useradd -g mysql mysql
>修改/app/mysql权限
chown -R mysql:mysql /app/mysql
>初始化配置,进入安装路径
cd /app/mysql
进入安装路径,执行初始化配置脚本,创建系统自带的数据库和表
chmod 755 scripts/mysql_install_db #赋予mysql_install_db执行权限 scripts/mysql_install_db --basedir=/app/mysql --datadir=/app/mysql/data --user=mysql |
注意:在/etc目录下会存在一个my.cnf,需要将此文件更名为其他的名字,如:/etc/my.cnf.bak,否则,该文件会干扰源码安装的MySQL的正确配置,造成无法启动在启动MySQL服务时,会按照一定次序搜索my.cnf,先在/etc目录下找,找不到则会搜索"$basedir/my.cnf",在本例中就是 /app/mysql/my.cnf,这是新版MySQL的配置文件的默认位置!需要检查下/etc目录下是否会多出一个my.cnf,如果多出,将它重命名成别的。否则,MySQL将使用这个配置文件启动,可能造成无法正常启动等问题。
启动服务
添加服务,拷贝服务脚本到init.d目录,并设置开机启动
cp support-files/mysql.server /etc/init.d/mysql
chkconfig mysql on
service mysql start --启动MySQL
配置用户
执行下面的命令修改root密码
mysql -uroot mysql> SET PASSWORD = PASSWORD('123456'); |
若要设置root用户可以远程访问,执行
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION; |
配置防火墙
防火墙的3306端口默认没有开启,若要远程访问,需要开启这个端口
打开/etc/sysconfig/iptables
在“-A INPUT –m state --state NEW –m tcp –p –dport 22 –j ACCEPT”,下添加:
-A INPUT -m state --state NEW -m tcp -p -dport 3306 -j ACCEPT |
然后保存,并关闭该文件,在终端内运行下面的命令,刷新防火墙配置:
systemctl restart firewalld
OK,配置完毕