티스토리 뷰

반응형

회사 사정상 고객 지원이 종료가 되었지만 억지로 사용하던 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

사용자 계정 백업및 복원.sql


 


반응형

'IT Story > DB' 카테고리의 다른 글

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
댓글