当前位置: 首页 > IT知识 > Linux系统下无法访问MySQL,解决方法分享

Linux系统下无法访问MySQL,解决方法分享

发布时间:2024-08-18 00:00:09 作者:电子资源网 阅读:2次

1、问题及异常

ThreadPoolAsynchronousRunner - com.mchange.v2.async.ThreadPoolAsynchronousRunner$DeadlockDetector@75d634ea -- APPARENT DEADLOCK!!! Complete Status:

Managed Threads: 3

Active Threads: 3

Active Tasks:

2、查找原因

费劲周知,确定是MySQL权限的问题

3、解决过程

1》 mysql -uroot -proot mydbName

2》 grant all privileges on *.* to wangs@‘%’ identified by ‘123456’;

3》 flush privileges;

4》 exit;

5》 /etc/init.d/mysql restart

4、命令的说明

进入 mysql ,用户为 root,密码为 root,数据库为 mydbName,-u 意为用户,-p 意为密码,

增加用户 wangs,所有权限,数据库为 *,后面的 .* 不可少,% 代表对所有远程的 IP 地址,如果要限定 IP 地址的话,单独写上 IP 地址,

密码是 123456,注意引号 ‘ 不可少,用来表示是字符串。

以上命令和过程均不可省略。

深入探讨:深度系统如何灵活分区

最新的系统deepin运行良好,但是我们在使用电脑系统时经常会对电脑磁盘进行分区。但是很多朋友对这个系统分区不太了解,不知道怎么操作才能分区系统。

操作方法:

1、点击任务栏中的启动器,找到并点击“分区编辑器”。

deepin系统如何分区

2、运行分区编辑器,随后输入当前的用户密码来授权。

deepin系统如何分区

3、打开分区编辑器后选择要分区的硬盘。

deepin系统如何分区

4、随后点击“设备”—》“新建”。

deepin系统如何分区

5、按照默认设置即可,点击“应用”即可使用。

deepin系统如何分区

6、完成后点击上方任务栏中的“分区”。

deepin系统如何分区

7、进行先关设置之后点击“添加”即可完成。

deepin系统如何分区

如何清理和预防Linux系统中的僵尸进程

linux 如何清理僵尸进程?一些朋友在维护服务器的时候,发现有5个nova-novncproxy的僵尸进程,面对这些僵尸进程,我们该如何应对呢?其实也不难,下面教大家查杀和避免僵尸进程

查杀和避免僵尸进程方法

0126327 ? S 0:05 \_ /usr/bin/python /usr/bin/nova-novncproxy --config-file=/etc/nova/nova.conf 024765 ? Z 0:00 \_ [nova-novncproxy] <defunct> 034766 ? Z 0:00 \_ [nova-novncproxy] <defunct> 044767 ? Z 0:00 \_ [nova-novncproxy] <defunct> 054768 ? Z 0:00 \_ [nova-novncproxy] <defunct> 064769 ? Z 0:00 \_ [nova-novncproxy] <defunct> 复制代码

定义:

In UNIX System terminology, a process that has terminated,but whose parent has not yet waited for it, is called a zombie.

在UNIX 系统中,一个进程结束了,但是他的父进程没有等待(调用wait / waitpid)他, 那么他将变成一个僵尸进程。 在fork()/execve()过程中,假设子进程结束时父进程仍存在,而父进程fork()之前既没安装SIGCHLD信号处理函数调用 waitpid()等待子进程结束,又没有显式忽略该信号,则子进程成为僵尸进程。

如何查看linux系统上的僵尸进程,如何统计有多少僵尸进程?

01#ps -ef | grep defunct 复制代码 或者查找状态为Z的进程,Z就是代表zombie process,僵尸进程的意思。

另外使用top命令查看时有一栏为S,如果状态为Z说明它就是僵尸进程。

  1. 01Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
复制代码

top命令中也统计了僵尸进程。或者使用下面的命令:

  1. 01ps -ef | grep defunct | grep -v grep | wc -l
复制代码

如何杀死僵尸进程呢?

一般僵尸进程很难直接kill掉,不过您可以kill僵尸爸爸。父进程死后,僵尸进程成为”孤儿进程”,过继给1号进程init,init始终会负责清理僵尸进程.它产生的所有僵尸进程也跟着消失。

01ps -e -o ppid,stat | grep Z | cut -d” ” -f2 | xargs kill -9 复制代码

01kill -HUP `ps -A -ostat,ppid | grep -e ’^[Zz]‘ | awk ’{print $2}’` 复制代码

当然您可以自己编写更好的shell脚本,欢迎与大家分享。

我将nova-novncproxy stop后再start,僵尸进程即消失,问题解决。

另外子进程死后,会发送SIGCHLD信号给父进程,父进程收到此信号后,执行waitpid()函数为子进程收尸。就是基于这样的原理:就算父进程没有调用wait,内核也会向它发送SIGCHLD消息,而此时,尽管对它的默认处理是忽略,如果想响应这个消息,可以设置一个处理函数。

如何避免僵尸进程呢?

处理SIGCHLD信号并不是必须的。但对于某些进程,特别是服务器进程往往在请求到来时生成子进程处理请求。如果父进程不等待子进程结束,子进程将成为僵尸进程(zombie)从而占用系统资源。如果父进程等待子进程结束,将增加父进程的负担,影响服务器进程的并发性能。在Linux下 可以简单地将 SIGCHLD信号的操作设为SIG_IGN。

signal(SIGCHLD,SIG_IGN);

这样,内核在子进程结束时不会产生僵尸进程。这一点与BSD4不同,BSD4下必须显式等待子进程结束才能释放僵尸进程

或者

用两次fork(),而且使紧跟的子进程直接退出,是的孙子进程成为孤儿进程,从而init进程将负责清除这个孤儿进程。

关于linux系统清理僵尸进程的操作步骤就给大家分享到这里了,如果你在操作linux系统的过程中也发现了僵尸进程,那么可以按照小编描述的方法进行清理。

渝ICP备20008086号-14 违法和不良信息举报/未成年人举报:dzjswcom@163.com

CopyRight©2003-2018 违法和不良信息举报(12377) All Right Reserved