介绍

在开发或者运维过程中,我们连接数据库的时候突然会遇到"Too many Connections"这种报错信息;这时我们就需要排除一下是哪些程序客户端连接较多而没有释放。

查看mysql数据库连接数

查看最大连接数

show variables like 'max_connections';

查看已使用连接数

show status like 'max%connections';

发现已使用的已经大于最大连接数。

更改最大连接数

全局set(临时)

这种方式重启mysql后会失效。

set GLOBAL max_connections=1000;

mysql> set GLOBAL max_connections=1000;

Query OK, 0 rows affected (2.00 sec)

查看最大连接数

查看已使用连接数

发现由原来的152变成了159,可以更多的连接。

配置文件修改

修改/etc/my.cnf配置文件

在[mysqld]块中修改或添加:max_connections=1000,重启mysql。

查看数据库连接情况

查看数据库连接IP列表及数量

select SUBSTRING_INDEX(host,':',1) as ip , count(*) from information_schema.processlist group by ip;

查看数据库连接数

select count(*) from information_schema.processlist;

查看进程列表

(1)列出前100条

show processlist;

(2)列出所有

show full processlist;

(3)各列的含义

Id:该进程程序登录mysql时,系统分配的连接id,即为connection_id。

User:该进程程序连接mysql的用户。

Host:该进程程序连接mysql的ip。

db:该进程程序连接mysql的某个数据库。

Command:该进程程序执行的命令,取值为休眠(Sleep)、查询(Query)、连接(Connect)等。

Time:Command状态持续的时间,单位为秒。

State:使用当前的sql语句的状态,如starting。

Info:显示sql语句,如当前执行了show full processlist。

查看进程

查看连接数据库的java进程

数据库端口为3306,查看连接该端口的java程序进程

netstat -anp | grep 3306 | grep java

查看进程对应的程序

ps -ef | grep 进程号

统计某个进程连接数

netstat -anp | grep 3306 | grep 进程号 | wc -l

通过wc -l统计出某个进程的连接数。

通过上述一系列操作,我们大概就能知道哪个程序服务连接数较多了。如上述的23818这个进程的连接数最多,为136。这时就需要考虑是否程序中对数据库连接没有做一些限制。

Java程序配置数据库连接池

# 配置数据库【需要按照具体环境修改】

spring.datasource.url: jdbc:mysql://ip1:3306,ip2:3306,ip3:3306/dbName?useSSL=false&useUnicode=true&amp&characterEncoding=utf-8

# Username and password

spring.datasource.username: userA

#ENC()前缀为数据库密码密文处理,测试时可直接配置数据库密码如:spring.datasource.password =123456

spring.datasource.password: ENC(0cHjeDIecX6DZd+T8kfNuukmfdfdsfd)

#spring.datasource.password: 123456

# 指定获取连接时连接校验的sql查询语句

spring.datasource.validation-query: SELECT 1 FROM DUAL

# 配置获取连接等待超时的时间

spring.datasource.max-wait: 10000

# 获取连接时候验证,会影响性能

spring.datasource.test-on-borrow: true

# 配置获取连接池中最大空闲数

spring.datasource.max-idle: 30

# 配置获取连接池中最大活跃数

spring.datasource.max-active: 100

# 指定连接池中连接的最大生存时间,毫秒单位

spring.datasource.max-lifetime: 300000

# 指定数据库连接驱动

spring.datasource.driverClassName: com.mysql.jdbc.Driver

# 指定数据库类型为MYSQL

spring.jpa.database: MYSQL

# 查询时是否显示日志,无需修改

spring.jpa.show-sql: false

# Hibernate ddl auto (create, create-drop, update)

spring.jpa.hibernate.ddl-auto: update

# Naming strategy

spring.jpa.hibernate.naming-strategy: org.hibernate.cfg.ImprovedNamingStrategy

# stripped before adding them to the bean manager)

#spring.jpa.properties.hibernate.dialect: org.hibernate.dialect.MySQL5Dialect

#spring.jpa.properties.hibernate.dialect: com.xxx.yyy.demo.entity.MySQL5DialectUTF8

# 字段无修改命名

spring.jpa.hibernate.naming.physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl

# 遇到大写字母 加”_”的命名

# spring.jpa.hibernate.naming.physical-strategy=org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy

jasypt:

encryptor:

password: EbfYkitulv73I2p0mXI50JMXoaxZTKJ7

注意:其中的spring.jpa.properties.hibernate.dialect: com.xxx.yyy.demo.entity.MySQL5DialectUTF8即为数据库生成表时为utf-8的编码。

package com.xxx.yyy.demo.entity;

import org.hibernate.dialect.MySQL5InnoDBDialect;

/**

* 自动建表(字符集utf-8)

*/

public class MySQL5DialectUTF8 extends MySQL5InnoDBDialect {

@Override

public String getTableTypeString() {

return " ENGINE=InnoDB DEFAULT CHARSET=utf8";

}

}

linux查看客户端连接,MySQL—Linux查看客户端连接信息(连接数、进程等)相关推荐

  1. Linux里命令卸载mysql,linux中mysql完整卸载命令操作

    yum方式安装的mysql 1.yum remove mysql mysql-server mysql-libs compat-mysql51 2.rm -rf /var/lib/mysql 3.rm ...

  2. linux直接联网安装mysql,linux环境下安装mysql

    Linux下安装mysql Mysql数据库的安装对于开发者来说,是我们必然会面对的问题,它的安装过程其实并不复杂,并且网络上的安装教程也非常多,但是对于新手来说,很多时候按照教程也没有能够安装成功, ...

  3. linux安装后启动mysql,linux安装完mysql后启动错误

    redhat as 4,使用rpm包安装完mysql的server 跟client后执行以下命令出错. [root@ftp etc]# /usr/bin/mysqladmin -u root pass ...

  4. mysql 查看innodb版本,mysql中查看innodb版本的方法

    SELECT * FROM information_schema.plugins\G mysql 5.6.3-m6 的innodb版本为 1.2.3 查看版本方法,可以看到大版本 SELECT * F ...

  5. linux怎么删干净mysql,linux怎么干净卸载mysql

    1.查找以前是否装有mysql 命令:rpm -qa|grep -i mysql 可以看到如下图的所示: 说明之前安装了: MySQL-client-5.5.25a-1.rhel5 MySQL-ser ...

  6. linux安装rpm提示nokey,Linux rpm安装问题解决

    1.安装时提示:warning: *.rpm: Header V3 RSA/SHA256 Signature, keykey ID c105b9de: NOKEY 解决的方法就是在rpm 语句后面加上 ...

  7. mysql linux 客户端_MySQL—Linux查看客户端连接信息(连接数、进程等)

    介绍 在开发或者运维过程中,我们连接数据库的时候突然会遇到"Too many Connections"这种报错信息:这时我们就需要排除一下是哪些程序客户端连接较多而没有释放. 查看 ...

  8. MySQL—Linux查看客户端连接信息(连接数、进程等)及SpringBoot配置数据库模板

    关注微信公众号:CodingTechWork,一起学习进步. 介绍   在开发或者运维过程中,我们连接数据库的时候突然会遇到"Too many Connections"这种报错信息 ...

  9. linux mysql 客户端连接,linux系统中启动mysql方式已经客户端如和连接mysql服务器

    零点间的记录 一.启动方式 1.使用linux命令service 启动: service mysqld start 2.使用 mysqld 脚本启动: /etc/inint.d/mysqld star ...

最新文章

  1. WhatsApp与Gmail用户数均突破10亿大关
  2. ISME:污水厂抗性组受细菌组成和基因交换驱动且出水中抗性表达活跃
  3. OpenCV-Python 雪花飘落特效
  4. linux的特殊权限SUID、SGID和SBIT
  5. docker php伪静态无效,docker 安装 thinkphp+nginx
  6. matlab图像处理函数
  7. 百度希壤元宇宙平台上线首个汽车数字展厅 领克探索汽车营销新方式
  8. boost::mp11::mp_similar相关用法的测试程序
  9. 作为一个甘肃天水人,我对罐罐茶有一种特殊的情怀
  10. msf如何升级_Kali linux 2016.2(Rolling)中的Metasploit如何更新与目录结构初步认识...
  11. 面试准备——Java回顾:高级编程(多线程、常用类、集合、泛型、IO流、反射、动态代理、新特性)
  12. MySQL 双主单写,主库偶尔出现大量延迟的原因
  13. 4. PHP 操作 memcache(1)
  14. QQ登录pc端测试用例
  15. 新著作计划:《水利水电工程施工导流 水力计算与.NET编程》
  16. csdn账号密码泄露了吗
  17. 三十三个免费匿名临时邮箱服务
  18. 【Eclipse使用技巧】格式化代码的方法 + 解决注释是繁体字的方法
  19. win10使用pip安装tensorflow
  20. jmeter监听器---聚合数据样本展示

热门文章

  1. java诗句_java--补全诗句代码
  2. Vue3电影中后台开发纪实(九):项目简历与面试
  3. java数青蛙_第十一届蓝桥杯第三场软件类省赛 C++ B组 题解
  4. 买电脑看那些配置(附带图片轻松理解应用)
  5. QOpenGLWidget第七篇 vao、vbo随机绘制线
  6. 一台服务器可以架设几个不同的传奇版本
  7. onenote创建目录以及页面内索引目录
  8. docker下禅道忘记管理员密码怎么办
  9. 服务器cpu支持DDR4,支持DDR4 土豪专用至强18核处理器到来
  10. CSS 角标选中、右下角选中效果