SqlConnection 的连接池机制解析
提供一篇关于sqlconnection连接池详细,有需要的朋友参考一下。
物理连接建立时,需要做和服务器握手,解析连接字符串,授权,约束的检查等等操作,而物理连接建立后,这些操作就不会去做了。这些操作是需要一定的时间的。所以很多人喜欢用一个静态对象存储 SqlConnection 来始终保持物理连接,但采用静态对象时,多线程访问会带来一些问题,实际上,我们完全不需要这么做,因为 SqlConnection 默认打开了连接池功能,当程序 执行 SqlConnection.Close 后,物理连接并不会被立即释放,所以这才出现当循环执行 Open操作时,执行时间几乎为0.
下面我们先看一下不打开连接池时,循环执行 SqlConnection.Open 的耗时
代码如下 | 复制代码 |
public static void OpenWithoutPooling() Stopwatch sw = new Stopwatch(); sw.Start(); sw.Stop(); sw.Reset(); sw.Start(); for (int i = 0; i
{ sw.Stop();
|
SqlConnection 默认是打开连接池的,如果要强制关闭,我们需要在连接字符串中加入 Pooling=False
调用程序如下:
代码如下 | 复制代码 |
Test.SqlConnectionTest.OpenWithoutPooling(); Console.WriteLine("Waiting for 10s"); System.Threading.Thread.Sleep(10 * 1000); Test.SqlConnectionTest.OpenWithoutPooling(); Console.WriteLine("Waiting for 600s"); System.Threading.Thread.Sleep(600 * 1000); Test.SqlConnectionTest.OpenWithoutPooling(); |
下面是测试结果
Without Pooling, first connection elapsed 13 ms
Without Pooling, average connection elapsed 5 ms
Wating for 10s
Without Pooling, first connection elapsed 6 ms
Without Pooling, average connection elapsed 4 ms
Wating for 600s
Without Pooling, first connection elapsed 7 ms
Without Pooling, average connection elapsed 4 ms
从这个测试结果看,关闭连接池后,平均每次连接大概要耗时4个毫秒左右,这个就是建立物理连接的平均耗时。
下面再看默认情况下的测试代码
代码如下 | 复制代码 |
public static void OpenWithPooling() sw.Start(); sw.Stop(); sw.Reset(); sw.Start(); for (int i = 0; i
{ sw.Stop();
Test.SqlConnectionTest.OpenWithPooling(); With Pooling, first connection elapsed 119 ms |
这个测试结果看,第一次耗时是119ms,这是因为我在测试代码中,首先运行的是这个测试过程,119 ms 是程序第一次启动时的首次连接耗时,这个耗时可能不光包括连接的时间,还有 ado.net 自己初始化的用时,所以这个用时可以不管。10秒以后在执行这个测试过程,首次执行的时间变成了0ms,这说明连接池机制发生了作用,SqlConnection Close 后,物理连接并没有被关闭,所以10秒后再执行,连接几乎没有用时间。
但我们发现一个有趣的现象,10分钟后,首次连接时间变成了6ms,这个和前面不打开连接池的测试用时几乎一样,也就是说10分钟后,物理连接被关闭了,又重新打开了一个物理连接。这个现象是因为连接池有个超时时间,默认情况下应该在5-10分钟之间,如果在此期间没有任何的连接操作,物理连接就会被关闭。那么我们有没有办法始终保持物理连接呢?方法是有的。
连接池设置中有一个最小连接池大小,默认为0,我们把它设置为大于0的值就可以保持若干物理连接始终不释放了。看代码
代码如下 | 复制代码 |
public static void OpenWithPooling(int minPoolSize) Stopwatch sw = new Stopwatch(); sw.Start(); sw.Stop(); sw.Reset(); sw.Start(); for (int i = 0; i
{ sw.Stop(); |
其实只要在连接字符串中加入一个 Min Pool Size=n 就可以了。
调用代码
代码如下 | 复制代码 |
Test.SqlConnectionTest.OpenWithPooling(1); With Pooling Min Pool Size=1, first connection elapsed 5 ms |
我们可以看到当 Min Pool Size = 1 时,除了首次连接用时5ms以外,即便过了10分钟,用时还是0ms,物理连接没有被关闭。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









データベース アクセスのパフォーマンスを向上させるための php-fpm 接続プールの使用の概要: Web 開発において、データベース アクセスは最も頻繁で時間のかかる操作の 1 つです。従来の方法では、データベース操作ごとに新しいデータベース接続を作成し、使用後に接続を閉じます。この方法では、データベース接続の確立と終了が頻繁に発生し、システムのオーバーヘッドが増加します。この問題を解決するには、php-fpm 接続プール テクノロジを使用してデータベース アクセスのパフォーマンスを向上させることができます。接続プールの原理: 接続プールは、一定数のデータベースを組み合わせたキャッシュ技術です。

Python プログラムで MySQL 接続プールを適切に閉じるにはどうすればよいですか? Python でプログラムを作成する場合、多くの場合、データベースと対話する必要があります。 MySQL データベースは広く使用されているリレーショナル データベースであり、Python では、サードパーティのライブラリ pymysql を使用して MySQL データベースに接続し、操作できます。データベース関連のコードを作成する場合、特に接続プールを使用する場合に、データベース接続を正しく閉じる方法が非常に重要な問題になります。接続プーリングは管理です

Java 開発におけるネットワーク接続漏洩の問題を解決する方法 情報技術の急速な発展に伴い、Java 開発におけるネットワーク接続の重要性がますます高まっています。しかし、Java開発におけるネットワーク接続漏洩の問題が徐々に顕著になってきました。ネットワーク接続のリークは、システムのパフォーマンスの低下、リソースの浪費、システムのクラッシュなどを引き起こす可能性があります。そのため、ネットワーク接続のリークの問題を解決することが重要になっています。ネットワーク接続のリークとは、Java 開発時にネットワーク接続が正しく閉じられず、接続リソースが解放されず、システムが正常に動作しなくなることを意味します。ソリューションネットワーク

PHP を使用して MySQL 接続プールをセットアップすると、パフォーマンスとスケーラビリティが向上します。手順には次のものが含まれます。 1. MySQLi 拡張機能をインストールします。 2. 接続プール クラスを作成します。 3. 接続プール インスタンスを作成します。 5. 接続を取得および解放します。接続プーリングにより、アプリケーションはリクエストごとに新しいデータベース接続を作成することを回避できるため、パフォーマンスが向上します。

ASP.NET プログラムで MySQL 接続プールを正しく使用し、最適化するにはどうすればよいですか?はじめに: MySQL は、高いパフォーマンス、信頼性、使いやすさを特徴とする、広く使用されているデータベース管理システムです。 ASP.NET 開発では、データ ストレージに MySQL データベースを使用することが一般的な要件です。データベース接続の効率とパフォーマンスを向上させるには、MySQL 接続プールを正しく使用し、最適化する必要があります。この記事では、ASP.NET プログラムで MySQL 接続プールを正しく使用し、最適化する方法を紹介します。

Node.js プログラムで MySQL 接続プールを適切に使用してパフォーマンスを最適化する方法は?インターネット アプリケーションの継続的な開発により、データベースはほとんどのアプリケーションの中核になりました。 Node.js では、MySQL は最も一般的に使用されるリレーショナル データベースの 1 つです。ただし、同時実行性が高い状況では、MySQL 接続を直接使用するとパフォーマンスの低下が発生します。この問題を解決するには、MySQL 接続プールを使用してパフォーマンスを最適化します。接続プールは、確立された接続オブジェクトのコレクションです。接続プールを通じて、アプリケーションは

Node.js プログラムで MySQL 接続プールのトランザクション パフォーマンスを正しく使用および管理するにはどうすればよいですか?はじめに: インターネット技術の継続的な発展に伴い、Node.js は非常に人気のあるサーバーサイド開発言語になりました。多くの Web アプリケーションでは、データベースのトランザクション パフォーマンスがシステムの安定性と高い信頼性において重要な役割を果たします。 MySQL は、Node.js プログラムで広く使用されているオープン ソースのリレーショナル データベース管理システムです。この記事では、正しい方法に焦点を当てます。

Gin フレームワークは、高性能で高可用性の Web 処理モデルを提供するように設計された軽量の Web フレームワークです。 Gin フレームワークでは、HTTP クライアントと接続プールが非常に重要なコンポーネントです。この記事では、Gin フレームワークの HTTP クライアントと接続プールの基礎となる実装の詳細について詳しく説明します。 1. HTTP クライアント HTTP クライアントは、HTTP リクエストを送信するための、Gin フレームワークのコア コンポーネントです。 Gin フレームワークでは、HTTP クライアントを実装するさまざまな方法がありますが、最も一般的に使用される 2 つの方法は次のとおりです。
