centos mysql 权限 centos sudo权限
大家好,今天给各位分享centos mysql 权限的一些知识,其中也会对centos sudo权限进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!
求助centos7,mysql 启动服务出错的问题
一、my.cnf配置文件datadir项配置错误或被启动脚本篡改
这个问题不太说讲,主要是mysql自带的启动文件(/etc/init.d/mysqld)中会自动检测mysql的数据存储目录,若mysql新装,尚未初始化系统表,那么配置文件中的datadir项写不写无所谓,出现这种情况主要是在更改了mysql的数据存储目录,今天我出现的这个问题就在于此。
我的mysql安装后的配置文件中关于datadir项目的配置如下,而该配置文件存储于/etc/my.cnf,今儿不知动了什么东西,查来查去都没找着原因,后来打开该配置文件才发现,其中的datadir项目被篡改成/var/mysql/data了.....
[mysqld] datadir=/data/mysql socket=/tmp/mysql.sock user=mysql
二、进程里已经存在mysql进程
这种情况我很少遇到,若存在mysql进程但有不提供mysql服务(表现为其他客户端连接不上mysql服务器,例如php连接mysql时提示“连接失败”),这个时候就要看看有没有存在的mysql僵尸进程了,命令如下:
ps-ef|grep mysql
若存在,该命令执行后会列出存在的僵尸进程,kill-9 `pid`掉即可。
三、mysql的数据存储目录权限不足
这种情况发生于mysql第一次安装或升级,配置文件中的datatdir目录的权限要设定好,一般来说运行mysql的用户以及组就是mysql.mysql,那么解决权限不足问题的方法如下:
chown-R mysql.mysql/data/mysql##该命令仅为示例,其中/data/mysql就是mysql配置文件中datadir的目录##若为空,则默认为mysql安装目录下的data文件夹下
四、覆盖安装或升级mysql后,残余数据的影响
这种情况发生于mysql被覆盖安装或升级后,当然mysql无故宕机后也会有这种情况,可能会影响mysql启动的数据文件,一般存在于mysql的数据存储目录(这个目录依据my.cnf配置文件中的datadir而异),也就是存在于mysql数据存储目录下的mysql-bin.index文件,删除之即可。
五、selinux的问题,centos下最容易出现
selinux不甚了解,直接关掉。
##方法1:永久关闭seliux##修改 vi/etc/selinux/config#文件中设置SELINUX=disabled,然后重启服务器##方法2:暂时关闭seliux setenforce 0##如需每次开机都铃声关闭seliux,则可以在/etc/rc.d/rc.local文件中添加该命令
六、mysql运行状态下删除binary日志后重启失败
这是今天在群里的一个朋友出现的,特汇总于此;当mysql开启了二进制日志并且mysql在运行状态下用rm命令删除过mysql的binary日志文件的话,下次重启mysql你就悲剧了。
什么是binary日志?说白了就是mysql的数据目录下的mysql-bin.000001、mysql-bin.000002的文件。
解决方法就是修改配置文件临时关闭binary-log,然后删除mysql数据目录下的所有类似mysql-bin.000001、mysql-bin.000002的文件后再次重启,mysql即可启动成功。
#mysql配置关闭二进制日志找到如下语句注释掉即可#log-bin=mysql-bin#binlog_format=mixed
此步骤操作完毕之后,若还需要启用二进制日志,那么就要先停掉mysql服务,然后修改msyql的配置文件,再次重启即可。
另外再附上正确删除mysql二进制日志文件的方法(绝对不是rm-rf命令直接删这些文件):
#第一步通过shell或cmd登录进mysql这步没什么好说的 msyql-u root-p***#第二步在mysql下直接执行清理binary日志命令 mysql> reset master#注意:此处仅针对单台mysql而言,若有互备mysql则执行该命令有风险。
CentOS 7 离线安装 MySQL
在CentOS 7中,若要离线安装MySQL,首先需要移除系统预装的MariaDB,以确保纯净的环境。执行以下步骤:
1.检查系统中是否已安装MariaDB,如果有,使用命令卸载:
<code>sudo yum remove MariaDB-server MariaDB-client</code>
2.接着,检查MySQL用户和组是否已存在。若不存在,创建它们:
<code>sudo useradd-r mysql&& sudo groupadd mysql&& sudo usermod-aG mysql mysql</code>
3.转至下载页面获取离线安装包:<a href="">MySQL官方网站下载页面,选择合适的版本,然后下载tar.gz文件。
4.将下载的包上传到服务器,解压缩并重命名安装目录,如:<code>sudo tar-xvf mysql-5.7.25.tar.gz&& sudo mv mysql-5.7.25 mysql_install
5.将目录权限调整为所有用户组所有:
<code>sudo chown-R mysql:mysql mysql_install</code>
6.创建MySQL的启动配置文件my.cnf,以定义安装细节。
7.进入MySQL文件夹,执行安装命令:<code>cd mysql_install&& sudo./scripts/mysql_install_db--user=mysql--ldata=/var/lib/mysql--basedir=.
8.配置MySQL为开机自启动:<code>sudo systemctl enable mysqld
9.设置环境变量,让系统能够识别MySQL安装路径:<code>sudo vi/etc/profile,添加MySQL路径,然后执行source命令使更改生效。
10.完成安装后,安全起见,请修改初始密码并配置远程访问权限,以满足应用需求。
解决centos的mysql服务3306端口无法远程连接10038问题
在上一篇文章中,我们探讨了如何在CentOS环境中安装宝塔控制面板并创建数据库。然而,当尝试在Windows上使用Navicat for MySQL远程连接时,却遇到了10038错误。此刻,我找到了一个有效的解决方案,让我们一起梳理这个问题的解决过程。
我们的服务器环境是基于CentOS 7.5.1804,一个强大而稳定的操作系统:
LSB Version:</ core-4.1-amd64:core-4.1-noarch
Distributor ID:</ CentOS
Description:</ CentOS Linux release 7.5.1804(Core)
Codename:</ Core
以下是问题出现的步骤:
在宝塔控制面板中新建数据库,并为新用户分配适当权限。
尝试使用Navicat连接,但本地连接极其缓慢,最终出现10038错误。
问题的关键在于,虽然我们最初以为是MySQL用户组的远程连接设置问题,但实际上问题出在MySQL的默认端口3306被服务器防火墙阻止了。
首先,确保服务器上安装了端口扫描工具nmap,如果没有,可以使用以下命令安装:
sudo yum install nmap
接下来,通过nmap检查3306端口状态:
nmap
如果结果显示为"filtered",说明可能被防火墙拦截。
确认防火墙状态,CentOS 7.5.1804使用firewalld服务:
sudo systemctl status firewalld
如果"active(running)",说明防火墙已启用。为了开放3306端口,我们可以执行以下命令以永久生效:
sudo firewall-cmd--zone=public--add-port=3306/tcp--permanent
或者,直接编辑firewalld配置文件(public.xml):
sudo nano/etc/firewalld/zones/public.xml
添加完毕后,重载防火墙以应用更改:
sudo firewall-cmd--reload
再次使用nmap检查3306端口,确认其状态是否变为"open",表示连接已成功。
如果需要删除之前开放的特定端口,可以使用以下命令:
sudo firewall-cmd--zone=public--remove-port=80/tcp--permanent
最后,如果需要调整MySQL用户权限,包括root用户,可以按照以下步骤操作:
登录数据库:mysql-uroot-p
为指定IP(如202.11.10.253)和用户名(如root)分配权限:GRANT ALL PRIVILEGES ON*.* TO'root'@'%' IDENTIFIED BY'youpassword' WITH GRANT OPTION;
刷新权限:FLUSH PRIVILEGES;
现在,你应该已经成功解决了CentOS服务器上MySQL 3306端口的远程连接问题,可以愉快地在Windows上使用Navicat进行操作了。