非域環境下SQL Server mirror建立
環境:
SQLServer2012SP1
主:10.202.11.47
備:10.202.11.49
不配置見證伺服器
步驟:
第1 步:建立master key(主金鑰)
主庫中執行:
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'Aa000000'
檢視主金鑰是否建立:
select is_master_key_encrypted_by_server ,* from sys . databases
備庫中執行同樣操作:
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'Aa000000'
第2 步:建立證照使用金鑰加密
主庫中執行:
USE master
GO
CREATE CERTIFICATE Host_A_Cert
WITH Subject = 'Host_47 Certificate' ,
Expiry_Date = '2055-1-1' ; -- 過期日期
備庫中執行:
USE master
GO
CREATE CERTIFICATE Host_B_Cert
WITH Subject = 'Host_49 Certificate' ,
Expiry_Date = '2055-1-1' ; -- 過期日期
第3 步:建立endpoint
主庫中執行:
IF NOT EXISTS
( SELECT 1 FROM sys . database_mirroring_endpoints )
BEGIN
CREATE ENDPOINT [Mirroring] STATE = STARTED AS TCP (
LISTENER_PORT = 5022 , LISTENER_IP = ALL ) FOR DATABASE_MIRRORING ( AUTHENTICATION =
CERTIFICATE Host_A_Cert , ENCRYPTION = REQUIRED Algorithm AES , ROLE =ALL )
END
如果存在endpoint則可以修改使用
SELECT * FROM sys . database_mirroring_endpoints
ALTER ENDPOINT [Mirroring] STATE = STARTED AS TCP (
LISTENER_PORT = 5022 , LISTENER_IP = ALL ) FOR DATABASE_MIRRORING ( AUTHENTICATION =
CERTIFICATE Host_A_Cert , ENCRYPTION = REQUIRED Algorithm AES , ROLE =ALL )
備庫中執行:
IF NOT EXISTS
( SELECT 1 FROM sys . database_mirroring_endpoints )
BEGIN
CREATE ENDPOINT [Mirroring] STATE = STARTED AS TCP (
LISTENER_PORT = 5022 , LISTENER_IP = ALL ) FOR DATABASE_MIRRORING ( AUTHENTICATION =
CERTIFICATE Host_B_Cert , ENCRYPTION = REQUIRED Algorithm AES , ROLE =ALL )
END
第4 步:備份證照
主備庫OS中建立資料夾 C:\MIRROR
主庫中執行:
BACKUP CERTIFICATE HOST_A_cert TO FILE = 'C:\MIRROR\HOST_A_cert.cer' ;
備庫中執行:
BACKUP CERTIFICATE HOST_B_cert TO FILE = 'C:\MIRROR\HOST_B_cert.cer' ;
主備庫OS中相互copy證照
第5 步:建立登入login
主庫中執行:
CREATE LOGIN Host_B_Login WITH PASSWORD = 'Password666'
備庫中執行:
CREATE LOGIN Host_A_Login WITH PASSWORD = 'Password666'
第6 步:建立User並對映到login
主庫中執行:
CREATE USER Host_B_User For Login Host_B_Login ;
備庫中執行:
CREATE USER Host_A_User For Login Host_A_Login ;
第7 步:建立證照,並使用從夥伴伺服器中copy過來的證照匯入,再授權證照給賬號
*****************************************
如果存在則先刪除
IF EXISTS( select * from sys . certificates WHERE name = 'HOST_B_cert' )
DROP CERTIFICATE HOST_B_cert
GO
*****************************************
主庫中執行:
CREATE CERTIFICATE Host_B_Cert AUTHORIZATION Host_B_User FROM FILE = 'C:\MIRROR\Host_B_Cert.cer' ;
備庫中執行:
CREATE CERTIFICATE Host_A_Cert AUTHORIZATION Host_A_User FROM FILE = 'C:\MIRROR\Host_A_Cert.cer' ;
第8 步:授權connect on endpoint許可權至login
主庫中執行:
GRANT CONNECT ON ENDPOINT :: [Mirroring] TO [Host_B_Login]
備庫中執行:
GRANT CONNECT ON ENDPOINT :: [Mirroring] TO [Host_A_Login]
第9 步:備份還原db
主庫中執行:
右鍵需要做mirror的DB->Tasks->back up...
Backup type選擇Full,並設定back up to:備份檔案目錄,之後點OK完成Full backup
再Backup type選擇Transaction log,並設定back up to:備份檔案目錄, Options->Overwrite media->Back up to the existing media set,之後點OK完成Transaction backup
備庫中執行:
右鍵database->restore database
Device選擇主庫已備份的檔案
Options->recovery state:選擇restore with norecovery模式還原,否則會報錯Msg 1416
點選OK
第10 步:開啟mirror
在備庫上執行( 必須備庫上先執行 ):
IP TCP://10.202.11.47:5022 為主庫IP
ALTER DATABASE mesdb SET PARTNER = 'TCP://10.202.11.47:5022' ;
在主庫上執行:
IP TCP://10.202.11.49:5022 為備主庫IP
ALTER DATABASE mesdb SET PARTNER = 'TCP://10.202.11.49:5022' ;
此時,mirror已經開啟。主庫狀態已變為principal, synchronized
另,根據需求可以修改mirror為high performance模式(預設試high safety)
ALTER DATABASE mesdb SET SAFETY OFF
第11 步:可以對備庫mirror DB建立只讀快照DB(選用)
備庫中執行:
create database snap_mesdb
on ( name = mesdb , -- 檔案邏輯名,需要和 mes 中一致
filename = 'c:\db_snapshot\snap_mes_1.ss' –- 快照物理檔名,可隨便取
)
as snapshot of mesdb --- 需要做快照的 DB
至此,非域環境中SQL Server mirror的搭建完成
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/25583515/viewspace-2636654/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 非掃描式定位攻擊域內SQL ServerSQLServer
- 建立Python虛擬環境——下Python
- SQL Server索引 - 非聚集索引SQLServer索引
- RAC環境下建立物理DATAGUARD(1)
- RAC環境下建立物理DATAGUARD(2)
- Centos7下搭建Laravel環境(非docker)CentOSLaravelDocker
- 建立環境
- AD域環境的搭建 基於Server 2008 R2Server
- SQL Server建立dblink至MySQLServerMySql
- SQL Server下載SQLServer
- Docker-compose搭建ELK環境並同步MS SQL Server資料DockerSQLServer
- 在域環境下對賬戶的操作
- gym建立環境、自定義gym環境
- 開發環境下PP檔案的建立開發環境
- [SQL Server玩轉Python] 一.安裝環境及T-SQL呼叫python指令碼SQLServerPython指令碼
- 適用於SQL Server生產環境DBA的七大技巧SQLServer
- SQL Server 2019下載SQLServer
- Anaconda建立環境、刪除環境、環境重新命名、檢視環境名
- 在Windows下如何建立指定的虛擬環境Windows
- maven環境下建立一個spring的java工程MavenSpringJava
- python pipenv建立環境Python
- SQL Server 2016 + AlwaysOn 無域叢集SQLServer
- 【QT6】pycharm整合qt desinger(非anaconda等環境下)QTPyCharm
- SQLServer2012高可用映象資料庫 實施方案(非域環境)SQLServer資料庫
- SQL Server 非sysadmin賬號傳送郵件SQLServer
- Docker 環境下 Vue dev 跨域的深刻回憶DockerVuedev跨域
- Homestead 環境下,區域網域名訪問站點
- 建立 Python 虛擬環境Python
- anaconda建立虛擬環境
- 建立python虛擬環境Python
- pycharm+anaconda環境建立PyCharm
- 在linux環境下 開機掛載 windows server share目錄LinuxWindowsServer
- Window server 2016 搭建Java Web環境ServerJavaWeb
- Windows環境下的Nginx環境搭建WindowsNginx
- Windows 環境下 Python 環境安裝WindowsPython
- window環境下testlink環境搭建(xammp)
- Mac 下 vue 開發環境的搭建以及專案建立MacVue開發環境
- 配置SQL server遠端連線(區域網)SQLServer