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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  [66]  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
11997정성태7/30/201913451.NET Framework: 850. C# - Excel(을 비롯해 Office 제품군) COM 객체를 제어 후 Excel.exe 프로세스가 남아 있는 문제 [2]파일 다운로드1
11996정성태7/25/201915864.NET Framework: 849. C# - Socket의 TIME_WAIT 상태를 없애는 방법파일 다운로드1
11995정성태7/23/201918945.NET Framework: 848. C# - smtp.daum.net 서비스(Implicit SSL)를 이용해 메일 보내는 방법 [2]
11994정성태7/22/201914441개발 환경 구성: 454. Azure 가상 머신(VM)에서 SMTP 메일 전송하는 방법파일 다운로드1
11993정성태7/22/20199883오류 유형: 561. Dism.exe 수행 시 "Error: 2 - The system cannot find the file specified." 오류 발생
11992정성태7/22/201911671오류 유형: 560. 서비스 관리자 실행 시 "Windows was unable to open service control manager database on [...]. Error 5: Access is denied." 오류 발생
11991정성태7/18/20199179디버깅 기술: 128. windbg - x64 환경에서 닷넷 예외가 발생한 경우 인자를 확인할 수 없었던 사례
11990정성태7/18/201911382오류 유형: 559. Settings / Update & Security 화면 진입 시 프로그램 종료
11989정성태7/18/201910295Windows: 162. Windows Server 2019 빌드 17763부터 Alt + F4 입력시 곧바로 로그아웃하는 현상
11988정성태7/18/201911740개발 환경 구성: 453. 마이크로소프트가 지정한 모든 Root 인증서를 설치하는 방법
11987정성태7/17/201916721오류 유형: 558. 윈도우 - KMODE_EXCEPTION_NOT_HANDLED 블루스크린(BSOD) 문제 [1]
11986정성태7/17/20199511오류 유형: 557. 드라이브 문자를 할당하지 않은 파티션을 탐색기에서 드라이브 문자와 함께 보여주는 문제
11985정성태7/17/20199638개발 환경 구성: 452. msbuild - csproj에 환경 변수 조건 사용 [1]
11984정성태7/9/201917839개발 환경 구성: 451. Microsoft Edge (Chromium)을 대상으로 한 Selenium WebDriver 사용법 [1]
11983정성태7/8/20198896오류 유형: 556. nodemon - 'mocha' is not recognized as an internal or external command, operable program or batch file.
11982정성태7/8/20198894오류 유형: 555. Visual Studio 빌드 오류 - result: unexpected exception occured (-1002 - 0xfffffc16)
11981정성태7/7/201911076Math: 64. C# - 3층 구조의 신경망(분류)파일 다운로드1
11980정성태7/7/201921516개발 환경 구성: 450. Visual Studio Code의 Java 확장을 이용한 간단한 프로젝트 구축파일 다운로드1
11979정성태7/7/201911053개발 환경 구성: 449. TFS에서 gitlab/github등의 git 서버로 마이그레이션하는 방법
11978정성태7/6/201910401Windows: 161. 계정 정보가 동일하지 않은 PC 간의 인증을 수행하는 방법 [1]
11977정성태7/6/201914967오류 유형: 554. git push - error: RPC failed; HTTP 413 curl 22 The requested URL returned error: 413 Request Entity Too Large
11976정성태7/4/20199324오류 유형: 553. (잘못 인증 한 후) 원격 git repo 재인증 시 "remote: HTTP Basic: Access denied" 오류 발생
11975정성태7/4/201917834개발 환경 구성: 448. Visual Studio Code에서 콘솔 응용 프로그램 개발 시 "입력"받는 방법
11974정성태7/4/201913190Linux: 22. "Visual Studio Code + Remote Development"로 윈도우 환경에서 리눅스(CentOS 7) C/C++ 개발
11973정성태7/4/201912402Linux: 21. 리눅스에서 공유 라이브러리가 로드되지 않는다면?
11972정성태7/3/201915287.NET Framework: 847. JAVA와 .NET 간의 AES 암호화 연동 [1]파일 다운로드1
... 61  62  63  64  65  [66]  67  68  69  70  71  72  73  74  75  ...