Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행 [링크 복사], [링크+제목 복사]
조회: 11869
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13347정성태5/10/20233931.NET Framework: 2118. C# - Semantic Kernel의 Prompt chaining 예제파일 다운로드1
13346정성태5/10/20233778오류 유형: 858. RDP 원격 환경과 로컬 PC 간의 Ctrl+C, Ctrl+V 복사가 안 되는 문제
13345정성태5/9/20235058.NET Framework: 2117. C# - (OpenAI 기반의) Microsoft Semantic Kernel을 이용한 자연어 처리 [1]파일 다운로드1
13344정성태5/9/20236327.NET Framework: 2116. C# - OpenAI API 사용 - 지원 모델 목록 [1]파일 다운로드1
13343정성태5/9/20234200디버깅 기술: 192. Windbg - Hyper-V VM으로 이더넷 원격 디버깅 연결하는 방법
13342정성태5/8/20234123.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의
13341정성태5/8/20233909닷넷: 2114. C# 12 - 모든 형식의 별칭(Using aliases for any type)
13340정성태5/8/20233930오류 유형: 857. Microsoft.Data.SqlClient.SqlException - 0x80131904
13339정성태5/6/20234617닷넷: 2113. C# 12 - 기본 생성자(Primary Constructors)
13338정성태5/6/20234103닷넷: 2112. C# 12 - 기본 람다 매개 변수파일 다운로드1
13337정성태5/5/20234626Linux: 59. dockerfile - docker exec로 container에 접속 시 자동으로 실행되는 코드 적용
13336정성태5/4/20234386.NET Framework: 2111. C# - 바이너리 출력 디렉터리와 연관된 csproj 설정
13335정성태4/30/20234514.NET Framework: 2110. C# - FFmpeg.AutoGen 라이브러리를 이용한 기본 프로젝트 구성 - Windows Forms파일 다운로드1
13334정성태4/29/20234166Windows: 250. Win32 C/C++ - Modal 메시지 루프 내에서 SetWindowsHookEx를 이용한 Thread 메시지 처리 방법
13333정성태4/28/20233626Windows: 249. Win32 C/C++ - 대화창 템플릿을 런타임에 코딩해서 사용파일 다운로드1
13332정성태4/27/20233721Windows: 248. Win32 C/C++ - 대화창을 위한 메시지 루프 사용자 정의파일 다운로드1
13331정성태4/27/20233744오류 유형: 856. dockerfile - 구 버전의 .NET Core 이미지 사용 시 apt update 오류
13330정성태4/26/20233414Windows: 247. Win32 C/C++ - CS_GLOBALCLASS 설명
13329정성태4/24/20233622Windows: 246. Win32 C/C++ - 직접 띄운 대화창 템플릿을 위한 Modal 메시지 루프 생성파일 다운로드1
13328정성태4/19/20233259VS.NET IDE: 184. Visual Studio - Fine Code Coverage에서 동작하지 않는 Fake/Shim 테스트
13327정성태4/19/20233685VS.NET IDE: 183. C# - .NET Core/5+ 환경에서 Fakes를 이용한 단위 테스트 방법
13326정성태4/18/20235054.NET Framework: 2109. C# - 닷넷 응용 프로그램에서 SQLite 사용 (System.Data.SQLite) [1]파일 다운로드1
13325정성태4/18/20234403스크립트: 48. 파이썬 - PostgreSQL의 with 문을 사용한 경우 연결 개체 누수
13324정성태4/17/20234238.NET Framework: 2108. C# - Octave의 "save -binary ..."로 생성한 바이너리 파일 분석파일 다운로드1
13323정성태4/16/20234137개발 환경 구성: 677. Octave에서 Excel read/write를 위한 io 패키지 설치
13322정성태4/15/20234936VS.NET IDE: 182. Visual Studio - 32비트로만 빌드된 ActiveX와 작업해야 한다면?
1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...