Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행 [링크 복사], [링크+제목 복사],
조회: 20039
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

docker - Sybase Anywhere 16 컨테이너 실행

Sybase SQL Anywhere 제품도 현재 공식 이미지는 제공되지 않습니다. 그래서 다음의 이미지를 사용해 볼 텐데,

jaschweder/sybase
; https://hub.docker.com/r/jaschweder/sybase

jaswdr / docker-image-sybase
; https://github.com/jaswdr/docker-image-sybase

docker pull jaschweder/sybase

docker run --name sqlany1 -p 2638:2638 jaschweder/sybase
    docker run --name sqlany1 --restart=always -d -p 2638:2638 jaschweder/sybase

실행 후 다음과 같은 로그를 볼 수 있고,

c:\temp> docker run --name sqlany1 -p 2638:2638 jaschweder/sybase
SQL Anywhere Network Server Version 16.0.0.2043
Developer edition, not licensed for deployment.

Copyright (c) 2014 SAP AG or an SAP affiliate company.
All rights reserved.
Use of this software is governed by the Sybase License Agreement.
Refer to http://www.sybase.com/softwarelicenses.

Connection limit (licensed seats): 3
Processors detected: 1 (containing 2 logical processors)
Maximum number of processors the server will use: 1 physical processor(s), 1 core(s)
This server is licensed to:
    Developer Edition
    Restricted Use
Running Linux 4.19.76-linuxkit #1 SMP Thu Oct 17 19:31:58 UTC 2019 on X86_64
Server built for X86_64 processor architecture
9100K of memory used for caching
Minimum cache size: 9100K, maximum cache size: 1808468K
Using a maximum page size of 4096 bytes
Multiprogramming level: minimum:2, current:20, maximum:80
Automatic tuning of multiprogramming level is enabled
Starting database "demo" (/opt/sqlanywhere16/demo.db) at Sat Mar 14 2020 11:45
Transaction log: demo.log
Starting checkpoint of "demo" (demo.db) at Sat Mar 14 2020 11:45
Finished checkpoint of "demo" (demo.db) at Sat Mar 14 2020 11:45
Database "demo" (demo.db) started at Sat Mar 14 2020 11:45
Database server started at Sat Mar 14 2020 11:45
Trying to start SharedMemory link ...
    SharedMemory link started successfully
Trying to start TCPIP link ...
Starting on port 2638
    TCPIP link started successfully
Now accepting requests

(GUI 도구인 Sybase Central을 포함하는) SQL Anywhere Database Client 프로그램을 이용해,

SAP SQL Anywhere Database Client Download
; https://archive.sap.com/documents/docs/DOC-35857

편하게 DB 구성을 할 수 있습니다.




그런데, 문제는 연결 정보입니다. 분명히 docker hub jaschweder/sybase 페이지에서는 다음과 같은 계정 정보가 있다고 하는데,

Environment Variables
    Guest user
        SYBASE_USER guest
        SYBASE_PASSWORD guest1234
        SYBASE_DB   guest
    Admin user
        SYBASE_USER sa
        SYBASE_PASSWORD password

실제로 Sybase Central 프로그램을 이용해 저 계정 정보로 로그인을 하려고 해도 다음과 같이 "Invalid user ID or password" 오류가 발생합니다.

[Sybase][ODBC Driver][SQL Anywhere]Invalid user ID or password
	SQLCODE=-103
	SQLSTATE=28000

Connection parameters:
	User=sa
	Password=***
	Host=192.168.100.50:2638
	LINKS=TCPIP
	ENC=NONE

혹시나 싶어 Sybase 문서에 있는,

Starting and connecting to a database on another computer (administration tools)
; http://infocenter.sybase.com/help/index.jsp?topic=/com.sybase.help.sqlanywhere.12.0.1/dbadmin/start-connect-another.html

기본 계정 정보를 입력해 보니,

Authentication: Database
User ID: dba
Password: sql
Action: Connect to a running database on another computer
Host: 192.168.100.50
Port: 2638
Server name: (empty) or (demo)
Database name: (empty) or (demo)

잘 됩니다. ^^; 어쨌든, Sybase Central로 접속할 수 있게 되었으니 이후부터는 아래의 글과 동일하게 클라이언트 측 코딩을 작성하면 됩니다.

C# - 닷넷 응용 프로그램에서 Sybase DB 사용
; https://www.sysnet.pe.kr/2/0/1410




volume 매핑은, 그냥 감각적으로 다음과 같이 지정했고,

docker run --name sqlany1 -p 2638:2638 -v sqlany16:/opt/sqlanywhere16 jaschweder/sybase

잘 동작합니다. ^^

[DockerDesktopVM의 파일 시스템 접근]

# ls /host/var/lib/docker/volumes/sqlany16/_data -l
total 3512
drwxrwxr-x    5 root     root          4096 Mar 14 11:57 bin64
drwxrwxr-x    2 root     root          4096 Mar 14 11:57 bin64s
drwxrwxr-x    3 root     root          4096 Mar 14 11:57 charsets
drwxrwxr-x    3 root     root          4096 Mar 14 11:57 collate
-rw-------    1 root     root       3334144 Mar 14 11:58 demo.db
-rw-r--r--    1 root     root          4096 Mar 14 11:58 demo.log
-rw-rw-r--    1 root     root           544 Feb 18  2019 installed.ini
drwxrwxr-x    2 root     root         28672 Mar 14 11:57 lib64
drwxrwxr-x    2 root     root          4096 Mar 14 11:57 res
-rw-rw-r--    1 root     root        202555 Feb 18  2019 uninstall.sh

참고로, "Sybase Central"을 통해 Database를 새로 생성하는 경우, 파일 경로를 "demo.db"와 같은 경로로 잡고 싶다면 "/opt/sqlanywhere16/testdb" 같은 식으로 입력해야 합니다.

CREATE DATABASE '/opt/sqlanywhere16/testdb.db' LOG ON 'testdb.log' COLLATION 'ISO1LATIN1' NCHAR COLLATION 'UCA' JCONNECT OFF;

아쉬운 것은, (demo를 제외하고) 새로 생성한 database가 기본적으로는 원격에서 "시작"할 수 있는 권한이 없어 "Sybase Central"을 통해 다른 컴퓨터에서 접속하는 경우 이런 오류가 발생합니다.

Connection failed.
[Sybase][ODBC Driver][SQL Anywhere]Request to start/stop database denied
Sat Mar 14 2020 21:45:33
21:45:33 Attempting to connect using:
UID=dba;PWD=********;DBN=testdb;DBF=/opt/sqlanywhere16/testdb;ServerName=demo;CON=SQL_DBC_1a6a2903e60;LOG=%LOCALAPPDATA%\Temp\3\testcon6776217579007205629.tmp;Host=192.168.100.50:2638
21:45:33 Attempting to connect to a running server...
21:45:33 Attempting TCPIP connection (address 192.168.100.50:2638 found in sasrv.ini cache)
21:45:33 Looking for server with name demo
21:45:33 Trying to find server at cached address 192.168.100.50:2638 without broadcasting
21:45:33 Found database server demo on TCPIP link
21:45:33 Connected using client address 192.168.100.51:51147
21:45:33 Connected to server over TCPIP
21:45:33 Connected to SQL Anywhere Server version 16.0.0.2043
21:45:33 Application information:
21:45:33 IP=192.168.100.51;HOST=testpc;OSUSER='TESTUSER';OS='Windows 2012R2 Build 17763 ';EXE='C:\Program Files\SQL Anywhere 16\bin64\scjview.exe';PID=0x1ce4;THREAD=0x1be0;VERSION=16.0.0.2193;API=iAnywhereJDBC;TIMEZONEADJUSTMENT=540
21:45:33 Connected to the server, attempting to connect to a running database...
21:45:33 Database is running, but could not connect to it
21:45:33 Request to start/stop database denied
21:45:33 Client disconnected
21:45:33 Disconnected from server

그래서 미리 container 내부에서 실행시켜 둬야 하고,

c:\temp> docker exec -it sqlany1 /bin/bash

root@ada75548065c:/# /opt/sqlanywhere16/bin64/dbsrv16 -n testdb /opt/sqlanywhere16/testdb.db  -x "tcpip(PORT=2639)"
SQL Anywhere Network Server Version 16.0.0.2043
...[생략]...
Trying to start TCPIP link ...
Starting on port 2639
    TCPIP link started successfully
Now accepting requests
Press 'q' to shut down the database server

여기서 사용할 포트로 인해 애초부터 container 구동 시 이에 대한 배려를 해야 합니다.

docker run --name sqlany1 -p 2638:2638 -p 2639:2639 -v sqlany16:/opt/sqlanywhere16 jaschweder/sybase

위와 같은 작업이 번거롭다면 사용자 정의 Dockerfile을 만들어 위의 과정을 자동화하는 Entrypoint를 설정하면 됩니다.




Sybase SQL Anywhere로 테스트하는 경우 "Connection limit (licensed seats): 3"이기 때문에 다음과 같은 오류를 많이 보게 될 것입니다. ^^

Server Error in '/' Application.

데이터베이스 서버 연결 한도를 초과했습니다. 
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. 

Exception Details: iAnywhere.Data.SQLAnywhere.SAException: Database server connection limit exceeded(데이터베이스 서버 연결 한도를 초과했습니다.)

Source Error: 

Line 30:                 new SAConnection(connectionString))
Line 31:             {
Line 32:                 myConnection.Open();
Line 33: 
Line 34:                 // Create

Source File: C:\temp\Testprj\SybaseDefault.aspx.cs    Line: 32 

Stack Trace: 

[SAException (0x80004005): 데이터베이스 서버 연결 한도를 초과했습니다.]
   iAnywhere.Data.SQLAnywhere.SAInternalConnection.CheckException(Int32 idEx, Boolean freeConn) +80
   iAnywhere.Data.SQLAnywhere.SAInternalConnection..ctor(SAConnection parent, Boolean pooled, Object dtcTran, String connectionString, SAConnectionGroup connectionGroup) +197
   iAnywhere.Data.SQLAnywhere.SAConnectionPool..ctor(String connectionString, Hashtable connectionOption) +608
   iAnywhere.Data.SQLAnywhere.SAConnectionPoolManager.AllocateConnection(SAConnection parent, Object dtcTran, String connectionString, Hashtable connectionOptions) +197
   iAnywhere.Data.SQLAnywhere.SAConnection.Open() +1052
   Testprj.SybaseDefault.Page_Load(Object sender, EventArgs e) in C:\temp\Testprj\SybaseDefault.aspx.cs:32
   System.Web.UI.Control.OnLoad(EventArgs e) +108
   System.Web.UI.Control.LoadRecursive() +90
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +1607
}

그리고 테스트를 하다 보면 (트랜잭션 로그를 사용하도록 지정한 DB인 경우) log 파일의 용량이 꽤나 커질 수 있는데, 주기적으로 truncate 시킬 필요가 있습니다.

How to Truncate and Manage a Transaction Log file (.log) in SQL Anywhere
; https://dscallards.freshdesk.com/support/solutions/articles/17000077798-how-to-truncate-and-manage-a-transaction-log-file-log-in-sql-anywhere

BACKUP DATABASE DIRECTORY ''
     TRANSACTION LOG ONLY
     TRANSACTION LOG TRUNCATE;




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 3/15/2020]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  [116]  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11024정성태8/12/201621624오류 유형: 350. "nProtect GameMon" 실행 중에는 Visual Studio 디버깅이 안됩니다! [1]
11023정성태8/10/201623065개발 환경 구성: 293. Azure 구독 후 PaaS 서비스 만들어 보기
11022정성태8/10/201623734개발 환경 구성: 292. Azure Cloud Service 배포시 사용자 정의 작업을 추가하는 방법
11021정성태8/10/201620856오류 유형: 349. System.Runtime.Remoting.RemotingException - Type '..., ..., Version=..., Culture=neutral, PublicKeyToken=null' is not registered for activation [2]
11020정성태8/10/201623562VC++: 98. 원본과 대상 버퍼가 같은 경우 memcpy, wmemcpy 주의점
11019정성태8/10/201640196기타: 60. 도서: 시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지 (2쇄 정오표)
11018정성태8/9/201624695.NET Framework: 600. 단일 메서드 내에서의 할당으로 알아보는 자바와 닷넷의 GC 차이점 [1]
11017정성태8/9/201626779웹: 33. HTTP 쿠키에 한글 값을 설정하는 방법
11016정성태8/7/201623927개발 환경 구성: 291. Windows Server Containers 소개
11015정성태8/7/201622214오류 유형: 348. Windows Server 2016 TP5에서 Windows Containers의 docker run 실행 시 encountered an error during Start failed in Win32
11014정성태8/6/201623021오류 유형: 347. Hyper-V Virtual Machine Management service Account does not have permission to open attachment
11013정성태8/6/201633723개발 환경 구성: 290. Windows 10에서 경험해 보는 Windows Containers와 docker [4]
11012정성태8/6/201623789오류 유형: 346. Windows 10에서 Windows Containers의 docker run 실행 시 encountered an error during CreateContainer failed in Win32 발생
11011정성태8/6/201625410기타: 59. outlook.live.com 메일 서비스의 아웃룩 POP3 설정하는 방법
11010정성태8/6/201622817기타: 58. Outlook에 설정한 SMTP/POP3(예:천리안 메일) 계정 암호를 잊어버린 경우
11009정성태8/3/201627995개발 환경 구성: 289. 2016-08-02부터 시작된 윈도우 10 1주년 업데이트에서 Bash Shell 사용 [8]
11008정성태8/1/201621787오류 유형: 345. 2의 30승 이상의 원소를 갖는 경우 버그가 발생하는 이진 검색(Binary Search) 코드
11007정성태8/1/201623535오류 유형: 344. RDP ActiveX 컨트롤로 특정 PC에 연결할 수 없을 때, 오류 상황을 해결하기 위한 팁파일 다운로드1
11006정성태7/22/201626533개발 환경 구성: 288. SSL 인증서를 Azure Cloud Service에 적용하는 방법
11005정성태7/22/201625190개발 환경 구성: 287. Let's Encrypt 인증서 업데이트 주기: 90일
11004정성태7/22/201620004오류 유형: 343. Invalid service definition or service configuration. Please see the Error List for more details.
11003정성태7/20/201627260VS.NET IDE: 110. Visual Studio 2015에서 .NET Core 응용 프로그램 개발 [1]
11002정성태7/20/201620737개발 환경 구성: 286. Microsoft Azure 서비스의 구독은 반드시 IE로!
11001정성태7/19/201631743.NET Framework: 599. .NET Core/SDK 설치 및 기본 사용법 [6]
11000정성태7/16/201620435오류 유형: 342. Microsoft Visual Studio 2010 Tools for Office Runtime (x86 and x64) 설치 시 오류
10999정성태7/16/201622013오류 유형: 341. .NET Framework 4.5.2가 설치 안 되는 경우
... 106  107  108  109  110  111  112  113  114  115  [116]  117  118  119  120  ...