[20171106]配置客戶端連接註意.txt

来源:http://www.cnblogs.com/lfree/archive/2017/11/07/7799857.html
-Advertisement-
Play Games

[20171106]配置客戶端連接註意.txt--//在配置客戶端連接時一般建議使用Net Manager工具,windows下調用執行Net Manager.--//linux下執行 netmgr,這樣能一定程度避免copy & paste的 錯誤.--//我這裡想說的是在連接類型選擇上一定要註意 ...


[20171106]配置客戶端連接註意.txt

--//在配置客戶端連接時一般建議使用Net Manager工具,windows下調用執行Net Manager.
--//linux下執行 netmgr,這樣能一定程度避免copy & paste的 錯誤.

--//我這裡想說的是在連接類型選擇上一定要註意,一般存在4中選擇:
資料庫預設設置
專用伺服器
共用伺服器
池中伺服器.

--//最好明確設置那種模式,而不是選擇"資料庫預設設置"模式,這樣會導致以後配置啟用"共用伺服器"出現問題.
--//最近我們生產系統就遭遇這樣的問題,還是通過例子說明:

1.環境:
SYS@book> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

--//我在我的client配置如下:
R:\>cat tnsnames.ora
# tnsnames.ora Network Configuration File: r:\tnsnames.ora
# Generated by Oracle configuration tools.
BOOK =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.78)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = book)
    )
  )

BOOK1 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.78)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = book)
    )
  )

BOOK2 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.78)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVER = SHARED)
      (SERVICE_NAME = book)
    )
  )

--//註第一種情況連接串BOOK就是"資料庫預設設置".沒有明確參數SERVER的值.許多開發包括我們下發的程式都是這樣設置的.

2.我開啟共用服務模式:
SYS@book> show parameter dispatchers
NAME             TYPE     VALUE
---------------- -------- -------------------------------------
dispatchers      string   (PROTOCOL=TCP) (SERVICE=book,bookXDB)
max_dispatchers  integer

SYS@book> show parameter shared_server
NAME                   TYPE    VALUE
---------------------- ------- -----
max_shared_servers     integer 1
shared_server_sessions integer
shared_servers         integer 1


--//我打開2個會話:
R:\>sqlplus scott/book@book
R:\>sqlplus scott/book@book

--//打開另外會話以sys用戶執行如下(session 3):
--//session 3:
SELECT s.sid
      ,s.serial#
      ,p.spid
      ,p.pid
      ,p.serial# p_serial#
      ,s.SERVER
      ,s.status
      ,s.username
      ,   'alter system kill session '''
       || s.sid
       || ','
       || s.serial#
       || ''''
       || ' immediate;'
          c50
  FROM v$session s, v$process p
WHERE s.paddr = p.addr and s.username='SCOTT';


  SID SERIAL# SPID       PID  P_SERIAL# SERVER    STATUS   USERNAME   C50
----- ------- ------ ------- ---------- --------- -------- ---------- --------------------------------------------------
  262     241 5750        19          1 NONE      INACTIVE SCOTT      alter system kill session '262,241' immediate;
  263      77 5750        19          1 NONE      INACTIVE SCOTT      alter system kill session '263,77' immediate;

--//你可以發現現在2個會話沒有執行任何語句,status='INACTIVE',server='NONE'.如果你在其中會話執行語句.
--//session 1:
select count(*) from emp,emp,emp,emp,emp,emp,emp,emp;

--//session 3:
  SID SERIAL# SPID       PID  P_SERIAL# SERVER    STATUS   USERNAME   C50
----- ------- ------ ------- ---------- --------- -------- ---------- --------------------------------------------------
  263      77 5750        19          1 NONE      INACTIVE SCOTT      alter system kill session '263,77' immediate;
  262     241 5752        20          1 SHARED    ACTIVE   SCOTT      alter system kill session '262,241' immediate;

--//你可以發現其中1個會話status從'INACTIVE'->'ACTIVE',server從'NONE'=>SHARED.
--//在sessiono 1沒有執行結束時,在session 2執行:
SCOTT@book> select sysdate from dual ;
--//session 2會掛起,這個是因為我沒有設置dispatchers參數D000進程太少.

--//如果這時在執行如下:
R:\>sqlplus scott/book@book
SQL*Plus: Release 12.1.0.1.0 Production on Mon Nov 6 12:00:05 2017
Copyright (c) 1982, 2013, Oracle.  All rights reserved.
ERROR:
ORA-28547: connection to server failed, probable Oracle Net admin error

3.重覆測試看看awr報表:
--session 3:
exec dbms_workload_repository.create_snapshot();

--session 1:
select count(*) from emp,emp,emp,emp,emp,emp,emp,emp;

--session 2:
select sysdate from dual ;

--//等待結束.
--session 3:
exec dbms_workload_repository.create_snapshot();

--//查看awr報表.實際上根本看不出問題.

SYS@book> @ &r/wait
P1RAW            P2RAW            P3RAW                    P1         P2         P3        SID    SERIAL#       SEQ# EVENT                                    STATE               WAIT_TIME_MICRO SECONDS_IN_WAIT
---------------- ---------------- ---------------- ---------- ---------- ---------- ---------- ---------- ---------- ---------------------------------------- ------------------- --------------- ---------------
000000004D545300 0000000000000001 00               1297371904          1          0        262        241         77 SQL*Net message to client                WAITED SHORT TIME                 5              31

--//這個也是共用伺服器模式的弊端.執行的語句必須很快完成,不然會影響別的會話執行sql語句.blog.itpub.net/267265/viewspace-2124172/

4.如果增加參數max_shared_servers,max_dispatchers數量:
SYS@book> alter system set max_shared_servers=6 scope=memory;
System altered.

SYS@book> alter system set max_dispatchers=10 scope=memory ;
System altered.

SYS@book> alter system set dispatchers='(PROTOCOL=TCP) (SERVICE=book,bookXDB)(dispatchers=6)' scope=memory;
System altered.

SYS@book> alter system register ;
System altered.

$ ps -lef | egrep "d00[0-9]_book|UI[D]"
F S UID        PID  PPID  C PRI  NI ADDR SZ WCHAN  STIME TTY          TIME CMD
0 S oracle   53333     1  0  80   0 - 61860 poll_s 14:45 ?        00:00:00 ora_d000_book
0 S oracle   53471     1  0  80   0 - 61827 poll_s 14:56 ?        00:00:00 ora_d001_book
0 S oracle   53473     1  0  80   0 - 61827 poll_s 14:56 ?        00:00:00 ora_d002_book
0 S oracle   53475     1  0  80   0 - 61827 poll_s 14:56 ?        00:00:00 ora_d003_book
0 S oracle   53477     1  0  80   0 - 61827 poll_s 14:56 ?        00:00:00 ora_d004_book
0 S oracle   53479     1  0  80   0 - 61827 poll_s 14:56 ?        00:00:00 ora_d005_book

--//依次打開3個會話:
R:\>sqlplus scott/book@book
R:\>sqlplus scott/book@book
R:\>sqlplus scott/book@book

--//session 4:
SELECT s.sid
      ,s.serial#
      ,p.spid
      ,p.pid
      ,p.serial# p_serial#
      ,s.SERVER
      ,s.status
      ,s.username
      ,s.program
      ,p.program
      ,   'alter system kill session '''
       || s.sid
       || ','
       || s.serial#
       || ''''
       || ' immediate;'
          c50
  FROM v$session s, v$process p
WHERE s.paddr = p.addr and s.username='SCOTT';

       SID    SERIAL# SPID       PID  P_SERIAL# SERVER    STATUS   USERNAME PROGRAM      PROGRAM                    C50
---------- ---------- ------ ------- ---------- --------- -------- -------- ------------ -------------------------- --------------------------------------------------
       262         33 53471       29          4 NONE      INACTIVE SCOTT    sqlplus.exe  oracle@xxxxxdg4 (D001)     alter system kill session '262,33' immediate;
       261         11 53473       30          2 NONE      INACTIVE SCOTT    sqlplus.exe  oracle@xxxxxdg4 (D002)     alter system kill session '261,11' immediate;
       263          9 53479       33          1 NONE      INACTIVE SCOTT    sqlplus.exe  oracle@xxxxxdg4 (D005)     alter system kill session '263,9' immediate;

--//分別運行不同dispatchers上.這樣就不會存在阻塞.

--//session 1:
SCOTT@book> select count(*) from emp,emp,emp,emp,emp,emp,emp,emp;
...


--//session 2:
SCOTT@book> select sysdate from dual ;
SYSDATE
-------------------
2017-11-06 15:11:00

--//session 3:
SCOTT@book> select sysdate from dual ;
SYSDATE
-------------------
2017-11-06 15:11:03

--//如果要增加S00N進程數量,修改參數:

SYS@book> alter system set shared_servers=4 scope=memory ;
System altered.

$ ps -lef | egrep "s00[0-9]_book|UI[D]"
F S UID        PID  PPID  C PRI  NI ADDR SZ WCHAN  STIME TTY          TIME CMD
0 S oracle   53335     1  3  80   0 - 60697 poll_s 14:45 ?        00:00:55 ora_s000_book
0 S oracle   53617     1  0  80   0 - 60565 poll_s 15:13 ?        00:00:00 ora_s001_book
0 S oracle   53619     1  0  80   0 - 60565 poll_s 15:13 ?        00:00:00 ora_s002_book
0 S oracle   53621     1  0  80   0 - 60565 poll_s 15:13 ?        00:00:00 ora_s003_book

5.總結:
1.講了這麼多,回到前面遇到的問題,可以發現如果client配置時使用資料庫預設設置,在共用伺服器存在的情況下,會優先使用.這樣
  如果應用配置存在問題,特別是2層應用模式,全部使用共用伺服器模式連接資料庫,這樣如果某個sql執行很慢,就有可能阻塞業務的
  正常運行,即使你配置足夠的dispatchers.實際上如果你使用ezconnect連接也是共用模式.
  參考鏈接:  http://blog.itpub.net/267265/viewspace-2130292/=>[20161212]ezconnect與共用服務模式.txt
2.從上面的情況,說明在配置client時,需要選擇正確的連接類型,而不是選擇"資料庫預設設置",以免造成不必要麻煩.
3.如果這樣只能建立新的服務名,指派服務名使用共用伺服器模式.

SYS@book> show parameter service
NAME          TYPE   VALUE
------------- ------ ---------------
service_names string BOOK, BOOKSHARE

SYS@book> alter system set dispatchers='(PROTOCOL=TCP) (SERVICE=bookshare,bookXDB)(dispatchers=6)' scope=memory;
System altered.

--//修改連接串如下:

BOOKS =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.100.78)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVER = SHARED)
      (SERVICE_NAME = bookshare)
    )
  )

R:\>sqlplus scott/book@books
SCOTT@books> @ spid
       SID    SERIAL# SPID       PID  P_SERIAL# C50
---------- ---------- ------ ------- ---------- --------------------------------------------------
       171          7 53621       37          1 alter system kill session '171,7' immediate;

--//session 4:
SELECT s.sid
      ,s.serial#
      ,p.spid
      ,p.pid
      ,p.serial# p_serial#
      ,s.SERVER
      ,s.status
      ,s.username
      ,s.program
      ,s.SERVICE_NAME
      ,p.program
      ,   'alter system kill session '''
       || s.sid
       || ','
       || s.serial#
       || ''''
       || ' immediate;'
          c50
  FROM v$session s, v$process p
WHERE s.paddr = p.addr and s.username='SCOTT';

SID    SERIAL# SPID       PID  P_SERIAL# SERVER    STATUS   USERNAME PROGRAM     SERVICE_NAME PROGRAM                C50
--- ---------- ------ ------- ---------- --------- -------- -------- ----------- ------------ ---------------------- --------------------------------------------------
171          7 53727       32          6 NONE      INACTIVE SCOTT    sqlplus.exe BOOKSHARE    oracle@xxxxxdg4 (D004) alter system kill session '171,7' immediate;

--//退出重新登錄:
R:\>sqlplus scott/book@book
SCOTT@book> @ spid
       SID    SERIAL# SPID       PID  P_SERIAL# C50
---------- ---------- ------ ------- ---------- --------------------------------------------------
       184         19 53781       38          8 alter system kill session '184,19' immediate;

--//session 4:

SYS@book> /
SID    SERIAL# SPID       PID  P_SERIAL# SERVER    STATUS   USERNAME PROGRAM     SERVICE_NAME PROGRAM         C50
--- ---------- ------ ------- ---------- --------- -------- -------- ----------- ------------ --------------- --------------------------------------------------
184         19 53781       38          8 DEDICATED INACTIVE SCOTT    sqlplus.exe book         oracle@gxqyydg4 alter system kill session '184,19' immediate;
--//這樣連接模式就是專用伺服器模式.


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 在之前的html相關的介紹中,我們已經學習了使用table來佈局網站的首頁,但是使用這種方式來佈局的話有一些缺陷,所以筆者這裡就介紹一下如何使用DIV+CSS來對網站的首頁進行佈局! 一、DIV的相關介紹 Div 它是一個 html 標簽,一個塊級元素(單獨顯示一行)。它單獨使用沒有任何意義, ...
  • 轉自CSDN: ...
  • 轉自CSDN: 購物車 我的購物車 清空購物車批量刪除 name price nu... ...
  • 學習react,使用webpack構建工具 在html引入生成的bundle.js時,寫成了這樣子: 結果報錯: 為什麼呢? 這樣不就ok了嗎!!!!!!!! 答案:看不懂英文,代碼還是看得懂的~~ https://stackoverflow.com/questions/18239430/canno ...
  • 測量應用程式的方法之一是看性能。而性能的指標之一便是用戶體驗,通俗的說法就是“用戶是否需要等待更長的時間才能得到他們想要的東西”。 這個指標在不同的應用場合而有所改變。對於移動購物應用,響應時間不能超過幾秒鐘。對於員工的人力資源頁面,可能需要多花幾秒鐘的時間。 有很多關於性能如何影響用戶行為的研究: ...
  • MySQL關聯查詢的三種寫法: SELECT * FROM film JOIN film_actor ON (film.film_id = film_actor.film_id);SELECT * FROM film JOIN film_actor USING (film_id); --當兩個要關聯 ...
  • [20171107]dbms_shared_pool.pin.txt--//昨天與別人聊天提到,如果dbms_shared_pool.pin對象,可以改變對應的chunk的類型.我自己也不確定,做一次測試.1.環境:SCOTT@book> @ &r/ver1PORT_STRING VERSION B ...
  • [20171106]修改show spparameter的顯示寬度.txt--//很多年前做的,修改show parameter的顯示寬度.--//鏈接: [20121023]改變show parameter的顯示寬度.txt=>http://blog.itpub.net/267265/viewsp ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...