성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
[정성태] 만드실 수 있습니다. 단지, Unity 엔진 내의 스크립트와 W...
[공진영] 안녕하세요 좋은글 감사합니다. 현재 제가 wpf로 관제 모...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>docker - Sybase Anywhere 16 컨테이너 실행</h1> <p> Sybase SQL Anywhere 제품도 현재 공식 이미지는 제공되지 않습니다. 그래서 다음의 이미지를 사용해 볼 텐데,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > jaschweder/sybase ; <a target='tab' href='https://hub.docker.com/r/jaschweder/sybase'>https://hub.docker.com/r/jaschweder/sybase</a> jaswdr / docker-image-sybase ; <a target='tab' href='https://github.com/jaswdr/docker-image-sybase'>https://github.com/jaswdr/docker-image-sybase</a> </pre> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > docker pull jaschweder/sybase docker run --name sqlany1 -p 2638:2638 jaschweder/sybase docker run --name sqlany1 <span style='color: blue; font-weight: bold'>--restart=always -d</span> -p 2638:2638 jaschweder/sybase </pre> <br /> 실행 후 다음과 같은 로그를 볼 수 있고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > c:\temp> <span style='color: blue; font-weight: bold'>docker run --name sqlany1 -p 2638:2638 jaschweder/sybase</span> 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 </pre> <br /> (GUI 도구인 Sybase Central을 포함하는) SQL Anywhere Database Client 프로그램을 이용해,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > SAP SQL Anywhere Database Client Download ; <a target='tab' href='https://archive.sap.com/documents/docs/DOC-35857'>https://archive.sap.com/documents/docs/DOC-35857</a> </pre> <br /> 편하게 DB 구성을 할 수 있습니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 그런데, 문제는 연결 정보입니다. 분명히 docker hub <a target='tab' href='https://hub.docker.com/r/jaschweder/sybase'>jaschweder/sybase</a> 페이지에서는 다음과 같은 계정 정보가 있다고 하는데,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Environment Variables Guest user SYBASE_USER guest SYBASE_PASSWORD guest1234 SYBASE_DB guest Admin user SYBASE_USER sa SYBASE_PASSWORD password </pre> <br /> 실제로 Sybase Central 프로그램을 이용해 저 계정 정보로 로그인을 하려고 해도 다음과 같이 "Invalid user ID or password" 오류가 발생합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > [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 </pre> <br /> 혹시나 싶어 Sybase 문서에 있는,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Starting and connecting to a database on another computer (administration tools) ; <a target='tab' href='http://infocenter.sybase.com/help/index.jsp?topic=/com.sybase.help.sqlanywhere.12.0.1/dbadmin/start-connect-another.html'>http://infocenter.sybase.com/help/index.jsp?topic=/com.sybase.help.sqlanywhere.12.0.1/dbadmin/start-connect-another.html</a> </pre> <br /> 기본 계정 정보를 입력해 보니,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Authentication: Database <span style='color: blue; font-weight: bold'>User ID: dba Password: sql</span> 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) </pre> <br /> 잘 됩니다. ^^; 어쨌든, Sybase Central로 접속할 수 있게 되었으니 이후부터는 아래의 글과 동일하게 클라이언트 측 코딩을 작성하면 됩니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > C# - 닷넷 응용 프로그램에서 Sybase DB 사용 ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/1410'>https://www.sysnet.pe.kr/2/0/1410</a> </pre> <br /> <hr style='width: 50%' /><br /> <br /> volume 매핑은, 그냥 감각적으로 다음과 같이 지정했고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > docker run --name sqlany1 -p 2638:2638 <span style='color: blue; font-weight: bold'>-v sqlany16:/opt/sqlanywhere16</span> jaschweder/sybase </pre> <br /> 잘 동작합니다. ^^<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > [<a target='tab' href='https://www.sysnet.pe.kr/2/0/12174#volume'>DockerDesktopVM의 파일 시스템 접근</a>] # 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 <span style='color: blue; font-weight: bold'>demo.db</span> -rw-r--r-- 1 root root 4096 Mar 14 11:58 <span style='color: blue; font-weight: bold'>demo.log</span> -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 </pre> <br /> 참고로, "Sybase Central"을 통해 Database를 새로 생성하는 경우, 파일 경로를 "demo.db"와 같은 경로로 잡고 싶다면 "/opt/sqlanywhere16/testdb" 같은 식으로 입력해야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > CREATE DATABASE <span style='color: blue; font-weight: bold'>'/opt/sqlanywhere16/testdb.db'</span> LOG ON 'testdb.log' COLLATION 'ISO1LATIN1' NCHAR COLLATION 'UCA' JCONNECT OFF; </pre> <br /> 아쉬운 것은, (demo를 제외하고) 새로 생성한 database가 기본적으로는 원격에서 "시작"할 수 있는 권한이 없어 "Sybase Central"을 통해 다른 컴퓨터에서 접속하는 경우 이런 오류가 발생합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Connection failed. [Sybase][ODBC Driver][SQL Anywhere]<span style='color: blue; font-weight: bold'>Request to start/stop database denied</span> 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 </pre> <br /> 그래서 미리 container 내부에서 실행시켜 둬야 하고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > c:\temp> <span style='color: blue; font-weight: bold'>docker exec -it sqlany1 /bin/bash</span> root@ada75548065c:/# <span style='color: blue; font-weight: bold'>/opt/sqlanywhere16/bin64/dbsrv16 -n testdb /opt/sqlanywhere16/testdb.db -x "tcpip(PORT=2639)"</span> SQL Anywhere Network Server Version 16.0.0.2043 ...[생략]... Trying to start TCPIP link ... <span style='color: blue; font-weight: bold'>Starting on port 2639</span> TCPIP link started successfully Now accepting requests Press 'q' to shut down the database server </pre> <br /> 여기서 사용할 포트로 인해 애초부터 container 구동 시 이에 대한 배려를 해야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > docker run --name sqlany1 -p 2638:2638 <span style='color: blue; font-weight: bold'>-p 2639:2639</span> -v sqlany16:/opt/sqlanywhere16 jaschweder/sybase </pre> <br /> 위와 같은 작업이 번거롭다면 사용자 정의 Dockerfile을 만들어 위의 과정을 자동화하는 Entrypoint를 설정하면 됩니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> Sybase SQL Anywhere로 테스트하는 경우 "Connection limit (licensed seats): 3"이기 때문에 다음과 같은 오류를 많이 보게 될 것입니다. ^^<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 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 } </pre> <br /> 그리고 테스트를 하다 보면 (트랜잭션 로그를 사용하도록 지정한 DB인 경우) log 파일의 용량이 꽤나 커질 수 있는데, 주기적으로 truncate 시킬 필요가 있습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > How to Truncate and Manage a Transaction Log file (.log) in SQL Anywhere ; <a target='tab' href='https://dscallards.freshdesk.com/support/solutions/articles/17000077798-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</a> BACKUP DATABASE DIRECTORY '' TRANSACTION LOG ONLY TRANSACTION LOG TRUNCATE; </pre> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1398
(왼쪽의 숫자를 입력해야 합니다.)