회사 사정상 고객 지원이 종료가 되었지만 억지로 사용하던 DB서버(MSSQL2005)를 드디어 업그레이드 합니다.
지금부터 업그레이드 테스터 하면서 알게된 내용을 포스팅 할까 합니다.
서버 환경
기존서버
OS : Windows 2008 R2 Stn
DB : MSSQL2005 Stn
신규서버
OS : Windows 2017 Stn
DB : MSSQL 2017 Stn
업그레이드 시나리오 및 방법
1. DB전용 서버이기때문에 OS는 특별한것이 없이서 신규서버에 최신버전 OS 설치(Windows 2017)
2. MSSQL이 현재 사용하는 버전이 넘 구버전이라 마이그레이션이 정상적으로 안될까봐 걱정 많이했습니다.
그러나 현실은 같은 MS계열이라서 그런지 몇단계 점프하여 바로 작업을해도 문제없이 복원됩니다.
[작업순서]
1. MSSQL2005의 DB를 백업한다.
2. 1에서 백업한 백업본을 MSSQL2017 서버에 복원한다.( 문제없이 정상 복원됩니다.)
※ =*, *= 과 같은 쿼리는 left outer join 이나 right outer join으로 변경해야됩니다.
3. 사용자 계정 백업을 백업 하여 복원한다.
[작업 순서]
1. 기존 서버의 쿼리분석기에서(MSSQL2005) 아래 쿼리 실행
USE master
GO
IF OBJECT_ID ('sp_hexadecimal') IS NOT NULL
DROP PROCEDURE sp_hexadecimal
GO
CREATE PROCEDURE sp_hexadecimal
@binvalue varbinary(256),
@hexvalue varchar (514) OUTPUT
AS
DECLARE @charvalue varchar (514)
DECLARE @i int
DECLARE @length int
DECLARE @hexstring char(16)
SELECT @charvalue = '0x'
SELECT @i = 1
SELECT @length = DATALENGTH (@binvalue)
SELECT @hexstring = '0123456789ABCDEF'
WHILE (@i <= @length)
BEGIN
DECLARE @tempint int
DECLARE @firstint int
DECLARE @secondint int
SELECT @tempint = CONVERT(int, SUBSTRING(@binvalue,@i,1))
SELECT @firstint = FLOOR(@tempint/16)
SELECT @secondint = @tempint - (@firstint*16)
SELECT @charvalue = @charvalue +
SUBSTRING(@hexstring, @firstint+1, 1) +
SUBSTRING(@hexstring, @secondint+1, 1)
SELECT @i = @i + 1
END
SELECT @hexvalue = @charvalue
GO
IF OBJECT_ID ('sp_help_revlogin') IS NOT NULL
DROP PROCEDURE sp_help_revlogin
GO
CREATE PROCEDURE sp_help_revlogin @login_name sysname = NULL AS
DECLARE @name sysname
DECLARE @type varchar (1)
DECLARE @hasaccess int
DECLARE @denylogin int
DECLARE @is_disabled int
DECLARE @PWD_varbinary varbinary (256)
DECLARE @PWD_string varchar (514)
DECLARE @SID_varbinary varbinary (85)
DECLARE @SID_string varchar (514)
DECLARE @tmpstr varchar (1024)
DECLARE @is_policy_checked varchar (3)
DECLARE @is_expiration_checked varchar (3)
DECLARE @defaultdb sysname
IF (@login_name IS NULL)
DECLARE login_curs CURSOR FOR
SELECT p.sid, p.name, p.type, p.is_disabled, p.default_database_name, l.hasaccess, l.denylogin FROM
sys.server_principals p LEFT JOIN sys.syslogins l
ON ( l.name = p.name ) WHERE p.type IN ( 'S', 'G', 'U' ) AND p.name <> 'sa'
ELSE
DECLARE login_curs CURSOR FOR
SELECT p.sid, p.name, p.type, p.is_disabled, p.default_database_name, l.hasaccess, l.denylogin FROM
sys.server_principals p LEFT JOIN sys.syslogins l
ON ( l.name = p.name ) WHERE p.type IN ( 'S', 'G', 'U' ) AND p.name = @login_name
OPEN login_curs
FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @hasaccess, @denylogin
IF (@@fetch_status = -1)
BEGIN
PRINT 'No login(s) found.'
CLOSE login_curs
DEALLOCATE login_curs
RETURN -1
END
SET @tmpstr = '/* sp_help_revlogin script '
PRINT @tmpstr
SET @tmpstr = '** Generated ' + CONVERT (varchar, GETDATE()) + ' on ' + @@SERVERNAME + ' */'
PRINT @tmpstr
PRINT ''
WHILE (@@fetch_status <> -1)
BEGIN
IF (@@fetch_status <> -2)
BEGIN
PRINT ''
SET @tmpstr = '-- Login: ' + @name
PRINT @tmpstr
IF (@type IN ( 'G', 'U'))
BEGIN -- NT authenticated account/group
SET @tmpstr = 'CREATE LOGIN ' + QUOTENAME( @name ) + ' FROM WINDOWS WITH DEFAULT_DATABASE = [' + @defaultdb + ']'
END
ELSE BEGIN -- SQL Server authentication
-- obtain password and sid
SET @PWD_varbinary = CAST( LOGINPROPERTY( @name, 'PasswordHash' ) AS varbinary (256) )
EXEC sp_hexadecimal @PWD_varbinary, @PWD_string OUT
EXEC sp_hexadecimal @SID_varbinary,@SID_string OUT
-- obtain password policy state
SELECT @is_policy_checked = CASE is_policy_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM sys.sql_logins WHERE name = @name
SELECT @is_expiration_checked = CASE is_expiration_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM sys.sql_logins WHERE name = @name
SET @tmpstr = 'CREATE LOGIN ' + QUOTENAME( @name ) + ' WITH PASSWORD = ' + @PWD_string + ' HASHED, SID = ' + @SID_string + ', DEFAULT_DATABASE = [' + @defaultdb + ']'
IF ( @is_policy_checked IS NOT NULL )
BEGIN
SET @tmpstr = @tmpstr + ', CHECK_POLICY = ' + @is_policy_checked
END
IF ( @is_expiration_checked IS NOT NULL )
BEGIN
SET @tmpstr = @tmpstr + ', CHECK_EXPIRATION = ' + @is_expiration_checked
END
END
IF (@denylogin = 1)
BEGIN -- login is denied access
SET @tmpstr = @tmpstr + '; DENY CONNECT SQL TO ' + QUOTENAME( @name )
END
ELSE IF (@hasaccess = 0)
BEGIN -- login exists but does not have access
SET @tmpstr = @tmpstr + '; REVOKE CONNECT SQL TO ' + QUOTENAME( @name )
END
IF (@is_disabled = 1)
BEGIN -- login is disabled
SET @tmpstr = @tmpstr + '; ALTER LOGIN ' + QUOTENAME( @name ) + ' DISABLE'
END
PRINT @tmpstr
END
FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @hasaccess, @denylogin
END
CLOSE login_curs
DEALLOCATE login_curs
RETURN 0
GO
2. EXEC sp_help_revlogin 실행하면 아래 이미지와 같이 결과값이 출력됩니다.
3. 이동한 서버(MSSQL2017이 설치된서버)의 쿼리분석기에서 2번 메시지탭의 결과를 복사하여
붙여 넣기 한 후 실행을 하면 계정정보가 이전됩니다.
PS.만약 AD에 조인되어 도메인 형태의 계정일 경우 기존서버에 이동할 서버의 도메인이 다를 경우
도메인을 변경하여 실행하여야 합니다.
EX) 기존서버 도메인이 kindmaster.co.kr 이고 변경할 서버 도메인이 kindmaster.com 일 경우
create login [kindmaster.co.kr\ggachi] -> create login[kindmaster.com\ggachi] 로 변경하여
실행하면 됩니다.
출처 : https://support.microsoft.com/en-us/kb/918992
MS-SQL 시퀀스(Sequenc) (0) | 2018.12.05 |
---|---|
MSSQL 기본 명령어 정리 (0) | 2018.08.24 |
MSSQL 연결된 서버 사용하기 (0) | 2017.11.17 |
MSSQL 로그파일(LDF) 사이즈 줄이기 (0) | 2017.09.15 |
Mysql 외부접속 허용 방법 (0) | 2017.08.30 |
Blog is powered by kakao / Designed by 미스터짱