配置Oracle共享服务器
用户连接Oracle数据库服务器主要有两种方式:专有服务器连接和共享服务器连接,在专有服务器模式中,当客户端发出连接数据库的请
用户连接Oracle数据库服务器主要有两种方式:专有服务器连接和共享服务器连接
在专有服务器模式中,当客户端发出连接数据库的请求时,监听器负责把客户端连接到专有服务器进程,该专有服务器进程只为该会话的用户进程服务,即使处于空闲状态。专有服务器进程与用户进程之间是一一对应的,每个服务器进程都会使用系统资源,包括CPU周期和内存。
在负荷很高的系统中,由于专有服务器进程占用了内存和CPU资源,因而会对系统的可伸缩性产生负面影响,所以一般客户端要通过中间件的连接池连接到数据库的专有服务器,或者连接到数据库的共享服务器。
相关阅读:
Oracle 共享服务器(Shared Server/MTS)的配置简析
Oracle共享服务器的监听注册机制研究
在共享服务器模式中,客户端用户进程的连接请求将被监听器传送至负载最小的调度进程(dispatcher)中,调度进程负责将用户请求传递到SGA中一个公共的请求队列。空闲的共享服务器进程将完成请求队列中的用户请求,并将结果放到响应队列中,最后调度进程将取出响应队列中的结果返回给用户进程。
会话与调度进程的连接在会话期间持久存在,而与监听器的连接是短暂的。且所有的调度进程共享一个公共的请求队列,但是每个调度进程都具有独立的响应队列。
配置共享服务器
在服务器端,,共享服务器与数据库无关,而只与实例有关。通过实例动态注册,会为共享服务器自动配置监听器。
共享服务器需要配置两个必需的参数:dispatchers和shared_servers
dispatchers参数控制在实例中启动的调度进程数以及这些进程的行为(协议类型等),max_dispatchers参数指定了能够启动的调度进程数的上限。
shared_servers参数控制在实例中启动的共享服务器进程的数量。max_shared_servers参数指定了能够启动共享服务器进程数的上限,默认为processers参数值的1/8。
$grep -A 5 APPLE $TNS_ADMIN/tnsnames.ora
APPLE =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.90)(PORT = 1522))
)
SQL> !ps aux | grep ora_s0.._orcl | grep -v grep
oracle 5223 0.0 1.0 666136 15028 ? Ss 10:21 0:00 ora_s000_orcl
SQL> show parameter dispatchers
NAME TYPE VALUE
------------------------------------ ----------- ----------------------------------
dispatchers string (PROTOCOL=TCP) (SERVICE=orclXDB)
max_dispatchers integer
SQL> alter system set dispatchers='(PROTOCOL=TCP) (dispatchers=3)'; //创建3个调度进程D000、D001、D002
SQL> select name,network,paddr,status from v$dispatcher;
NAME NETWORK PADDR STATUS
----- ----------------------------------------------------------------- -------------------- ----------------
D000 (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=62238)) 000000007AC8AFF0 WAIT
D001 (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=54626)) 000000007AC8C030 WAIT
D002 (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=16374)) 000000007AC8D070 WAIT
SQL> !ps aux | grep ora_d0.._orcl | grep -v grep
oracle 9303 0.0 1.0 666976 15992 ? Ss 15:35 0:00 ora_d000_orcl
oracle 9392 0.0 1.0 666976 15976 ? Ss 15:38 0:00 ora_d001_orcl
oracle 9396 0.0 1.0 666976 16004 ? Ss 15:38 0:00 ora_d002_orcl
SQL> alter system set shared_servers=6; //创建6个响应队列S000~S005(一般为dispatchers的倍数)
SQL> select name,paddr,status,circuit from v$shared_server;
NAME PADDR STATUS CIRCUIT
---- ---------------- ---------------- ----------------
S000 000000007AC8E0B0 WAIT(COMMON) 00
S001 000000007AC8F0F0 WAIT(COMMON) 00
S002 000000007AC90130 WAIT(COMMON) 00
S003 000000007AC91170 WAIT(COMMON) 00
S004 000000007AC921B0 WAIT(COMMON) 00
S005 000000007AC94230 WAIT(COMMON) 00
SQL> !ps aux | grep ora_s0.._orcl | grep -v grep
oracle 5223 0.0 1.0 666136 15028 ? Ss 10:21 0:00 ora_s000_orcl
oracle 6692 0.1 1.0 666136 15028 ? Ss 11:13 0:00 ora_s001_orcl
oracle 6696 0.1 1.0 666136 15028 ? Ss 11:13 0:00 ora_s002_orcl
oracle 6700 0.0 1.0 666136 15032 ? Ss 11:13 0:00 ora_s003_orcl
oracle 6704 0.1 1.0 666136 15044 ? Ss 11:13 0:00 ora_s004_orcl
oracle 6708 0.1 1.0 666136 15032 ? Ss 11:13 0:00 ora_s005_orcl
SQL> alter system set dispatchers='(PROTOCOL=TCP) (dispatchers=3) (listener=apple)'; //单独将dispathers注册到LISTENER1的监听器上
SQL> !lsnrctl service listener1
---------------省略输出---------------
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.0.90)(PORT=1522)))
Services Summary...
Service "orcl.example.com" has 1 instance(s). Instance "orcl", status READY, has 4 handler(s) for this service...
Handler(s):
"DEDICATED" established:0 refused:0 state:ready
LOCAL SERVER
"D002" established:0 refused:0 current:0 max:972 state:ready
DISPATCHER
(ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=16374))
"D001" established:0 refused:0 current:0 max:972 state:ready
DISPATCHER
(ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=54626))
"D000" established:0 refused:0 current:1 max:972 state:ready
DISPATCHER
(ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=62238))
The command completed successfully
更多详情见请继续阅读下一页的精彩内容:

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MySQL在Web應用中的主要作用是存儲和管理數據。 1.MySQL高效處理用戶信息、產品目錄和交易記錄等數據。 2.通過SQL查詢,開發者能從數據庫提取信息生成動態內容。 3.MySQL基於客戶端-服務器模型工作,確保查詢速度可接受。

InnoDB使用redologs和undologs確保數據一致性和可靠性。 1.redologs記錄數據頁修改,確保崩潰恢復和事務持久性。 2.undologs記錄數據原始值,支持事務回滾和MVCC。

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。MySQL以其高性能、可扩展性和跨平台支持著称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

MySQL適合小型和大型企業。 1)小型企業可使用MySQL進行基本數據管理,如存儲客戶信息。 2)大型企業可利用MySQL處理海量數據和復雜業務邏輯,優化查詢性能和事務處理。

MySQL索引基数对查询性能有显著影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。
