Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행 [링크 복사], [링크+제목 복사]
조회: 11874
글쓴 사람
정성태 (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)
13474정성태12/6/20232133개발 환경 구성: 690. 닷넷 코어/5+ 버전의 ilasm/ildasm 실행 파일 구하는 방법 - 두 번째 이야기
13473정성태12/5/20232325닷넷: 2179. C# - 값 형식(Blittable)을 메모리 복사를 이용해 바이트 배열로 직렬화/역직렬화파일 다운로드1
13472정성태12/4/20232155C/C++: 164. Visual C++ - InterlockedCompareExchange128 사용 방법
13471정성태12/4/20232183Copilot - To enable GitHub Copilot, authorize this extension using GitHub's device flow
13470정성태12/2/20232483닷넷: 2178. C# - .NET 8부터 COM Interop에 대한 자동 소스 코드 생성 도입파일 다운로드1
13469정성태12/1/20232192닷넷: 2177. C# - (Interop DLL 없이) CoClass를 이용한 COM 개체 생성 방법파일 다운로드1
13468정성태12/1/20232175닷넷: 2176. C# - .NET Core/5+부터 달라진 RCW(Runtime Callable Wrapper) 대응 방식파일 다운로드1
13467정성태11/30/20232170오류 유형: 882. C# - Unhandled exception. System.Runtime.InteropServices.COMException (0x800080A5)파일 다운로드1
13466정성태11/29/20232376닷넷: 2175. C# - DllImport 메서드의 AOT 지원을 위한 LibraryImport 옵션
13465정성태11/28/20232109개발 환경 구성: 689. MSBuild - CopyToOutputDirectory가 "dotnet publish" 시에는 적용되지 않는 문제파일 다운로드1
13464정성태11/28/20232228닷넷: 2174. C# - .NET 7부터 UnmanagedCallersOnly 함수 export 기능을 AOT 빌드에 통합파일 다운로드1
13463정성태11/27/20232144오류 유형: 881. Visual Studio - NU1605: Warning As Error: Detected package downgrade
13462정성태11/27/20232209오류 유형: 880. Visual Studio - error CS0246: The type or namespace name '...' could not be found
13461정성태11/26/20232258닷넷: 2173. .NET Core 3/5+ 기반의 COM Server를 registry 등록 없이 사용하는 방법파일 다운로드1
13460정성태11/26/20232224닷넷: 2172. .NET 6+ 기반의 COM Server 내에 Type Library를 내장하는 방법파일 다운로드1
13459정성태11/26/20232207닷넷: 2171. .NET Core 3/5+ 기반의 COM Server를 기존의 regasm처럼 등록하는 방법파일 다운로드1
13458정성태11/26/20232212닷넷: 2170. .NET Core/5+ 기반의 COM Server를 tlb 파일을 생성하는 방법(tlbexp)
13457정성태11/25/20232163VS.NET IDE: 187. Visual Studio - 16.9 버전부터 추가된 "Display inline type hints" 옵션
13456정성태11/25/20232459닷넷: 2169. C# - OpenAI를 사용해 PDF 데이터를 대상으로 OpenAI 챗봇 작성 [1]파일 다운로드1
13455정성태11/25/20232339닷넷: 2168. C# - Azure.AI.OpenAI 패키지로 OpenAI 사용파일 다운로드1
13454정성태11/23/20232681닷넷: 2167. C# - Qdrant Vector DB를 이용한 Embedding 벡터 값 보관/조회 (Azure OpenAI) [1]파일 다운로드1
13453정성태11/23/20232217오류 유형: 879. docker desktop 설치 시 "Invalid JSON string. (Exception from HRESULT: 0x83750007)"
13452정성태11/22/20232296닷넷: 2166. C# - Azure OpenAI API를 이용해 사용자가 제공하는 정보를 대상으로 검색하는 방법파일 다운로드1
13451정성태11/21/20232431닷넷: 2165. C# - Azure OpenAI API를 이용해 ChatGPT처럼 동작하는 콘솔 응용 프로그램 제작파일 다운로드1
13450정성태11/21/20232253닷넷: 2164. C# - Octokit을 이용한 GitHub Issue 검색파일 다운로드1
13449정성태11/21/20232351개발 환경 구성: 688. Azure OpenAI 서비스 신청 방법
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...