Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행 [링크 복사], [링크+제목 복사],
조회: 12371
글쓴 사람
정성태 (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)
11922정성태5/29/201911583.NET Framework: 840. ML.NET 데이터 정규화파일 다운로드1
11921정성태5/28/201916520Math: 55. C# - 다항식을 위한 최소 자승법(Least Squares Method)파일 다운로드1
11920정성태5/28/201910091.NET Framework: 839. C# - PLplot 색상 제어
11919정성태5/27/201913241Math: 54. C# - 최소 자승법의 1차 함수에 대한 매개변수를 단순 for 문으로 구하는 방법 [1]파일 다운로드1
11918정성태5/25/201914408Math: 53. C# - 행렬식을 이용한 최소 자승법(LSM: Least Square Method)파일 다운로드1
11917정성태5/24/201914545Math: 52. MathNet을 이용한 간단한 통계 정보 처리 - 분산/표준편차파일 다운로드1
11916정성태5/24/201912517Math: 51. MathNET + OxyPlot을 이용한 간단한 통계 정보 처리 - Histogram파일 다운로드1
11915정성태5/24/201914816Linux: 11. 리눅스의 환경 변수 관련 함수 정리 - putenv, setenv, unsetenv
11914정성태5/24/201914510Linux: 10. 윈도우의 GetTickCount와 리눅스의 clock_gettime파일 다운로드1
11913정성태5/23/201912144.NET Framework: 838. C# - 숫자형 타입의 bit(2진) 문자열, 16진수 문자열 구하는 방법파일 다운로드1
11912정성태5/23/201911793VS.NET IDE: 137. Visual Studio 2019 버전 16.1부터 리눅스 C/C++ 프로젝트에 추가된 WSL 지원
11911정성태5/23/201910870VS.NET IDE: 136. Visual Studio 2019 - 리눅스 C/C++ 프로젝트에 인텔리센스가 동작하지 않는 경우
11910정성태5/23/201919544Math: 50. C# - MathNet.Numerics의 Matrix(행렬) 연산 [1]파일 다운로드1
11909정성태5/22/201913956.NET Framework: 837. C# - PLplot 사용 예제 [1]파일 다운로드1
11908정성태5/22/201912341.NET Framework: 836. C# - Python range 함수 구현파일 다운로드1
11907정성태5/22/201910127오류 유형: 541. msbuild - MSB4024 The imported project file "...targets" could not be loaded
11906정성태5/21/201910084.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/201910760.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/201917046.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보 [1]파일 다운로드1
11903정성태5/21/201912015오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/201911161오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/201912305오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태5/18/201911558오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/201912587Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/16/201913970VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/201920642오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우 [2]
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...