on 2017 Jan 19 3:28 AM
Hello,
I am trying to create and start a mobilink server service with dbsvc with the following command:
dbsvc -y -as -s Automatic -t MobiLink -sd SYCLOML -w SAAPML -u SAAPML "C:\\Program Files\\SQL Anywhere 16\\bin64\\mlsrv16.exe" dbsvc -u -c dsn=oracle_cons;uid=rbasu;pwd=rbasu -x tcpip(port=5555) -o "C:\\MobiLink\\logs\\ml_log.txt" -on 2M -zu+ -zp -dl -zw 0 -w 25 -v -ftr "D:\\usr\\sap\\TA1\\USR" -ftru "D:\\usr\\sap\\TA1\\USR"
It is creating the service successfully.
When I am trying to start the service with
dbsvc -u SAAMPL
It is throwing an error saying: SQL Anywhere Service Utility Version 16.0.0.1324 The system cannot find the file specified. Error starting service "SAAPML".
dbsvc -g SAAPML gives:
SQL Anywhere Service Utility Version 16.0.0.1324 Service "SAAPML": MobiLink Real service name: SQLANYm_SAAPML Display Name: SQL Anywhere - SAAPML Display Description: SYCLOML Service group: SQLANYMobiLink Automatic Startup Using LocalSystem account Not allowed to interact with desktop Executable: -u Service command line options: SAAPML "C:\\Program Files\\SQL Anywhere 16\\bin64\\mlsrv16.exe" dbsvc -u -c dsn=oracle_cons;uid=ML_R1;pwd=ML_R1 -x tcpip(port=5555) -o C:\\MobiLink\\logs\\ml_log.txt -on 2M -zu+ -zp -dl -zw 0 -w 25 -v -ftr D:\\usr\\sap\\TA1\\TARS -ftru D:\\usr\\sap\\TA1\\TARS
What file path do I need to check?
Modified the command to :
dbsvc -y -as -s Automatic -t MobiLink -sd SYCLOML -w SAAPML "C:\\Program Files\\SQL Anywhere 16\\bin64\\mlsrv16.exe" -c dsn=oracle_cons;uid=rbasu;pwd=rbasu -x tcpip(port=5555) -o "C:\\MobiLink\\logs\\ml_log.txt" -on 2M -zu+ -zp -dl -zw 0 -w 25 -v -ftr "D:\\usr\\sap\\TA1\\USR" -ftru "D:\\usr\\sap\\TA1\\USR"
And then started the service as
dbsvc -u SAAPML
SQL Anywhere Service Utility Version 16.0.0.1324 Service "SAAPML" start pending. Service "SAAPML" was started successfully.
Thanks
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Hi Volker,
I am creating the following dsn:
dbdsn -ws SAAP_RCS_rem_0101 -v -y -c "dbf=C:\\SAP\\SAAP\\0101\\db\\0101\\SAAP_RCS.db;uid=rohini;pwd=basu;eng=SAAPDB_RCS_SAPDOC01_0101;dbn=SAAP_RCS_rem_0101;commlinks=shmem"
Then I am trying to create and run SQL Anywhere 16 as windows service:
dbsvc -y -as -i -s Automatic -t Network -sd SAAPDB_RCS_SAPDOC01_0101 -w SAAPDB_RCS_SAPDOC01_0101 "C:\\Program Files\\SQL Anywhere 16\\Bin64\\dbsrv16.exe" -c dsn=SAAP_RCS_rem_0101;uid=rohini;pwd=basu -o C:\\SAP\\SAAP\\0101\\db\\logs\\eng_log_0101 -on 4M -x shmem,tcpip(port=5657) -xs http(port=8080;dbn=SAAP_RCS_rem_0101;MaxRequestSize=10M;log=C:\\SAP\\SAAP\\0101\\db\\logs\\web_log_0101.txt) -gd ALL SQL Anywhere Service Utility Version 16.0.0.2043 Service "SAAPDB_RCS_SAPDOC01_0101" was created successfully.
dbsvc -u SAAPDB_RCS_SAPDOC01_0101 SQL Anywhere Service Utility Version 16.0.0.2043 Service "SAAPDB_RCS_SAPDOC01_0101" start pending. Error starting service "SAAPDB_RCS_SAPDOC01_0101".
Can you please help me out here?
Hm, IMHO there's a wrong option within the dbsrv16.exe command line, "-c" is used to specify an initial cache size, not to specify a connection string (see, you want to start a database engine with a database, but you do make a connection when starting the database engine)... - In other words, you are not starting a database client here like DBISQL that would use -c to specify a connection string...
And therefore you do not specify a DSN when starting a database engine, but you use the -n options (as server option to specify the engine name and as database option to specify the database name) and name the database file path, such as...
..."C:\\Program Files\\SQL Anywhere 16\\Bin64\\dbsrv16.exe" -n SAAPDB_RCS_SAPDOC01_0101 C:\\SAP\\SAAP\\0101\\db\\0101\\SAAP_RCS.db -n SAAP_RCS_rem_0101 -o ...
I would highly recommend to try to start the engine directly per command line before trying to use the DBSVC statements, it will show you easier whether your command line is correct or not. Once it does work, then use it within DBSVC.
I replaced the -c option with -n as shown above. But no luck.
dbsvc -y -as -i -s Automatic -t Network -sd SAAPDB_RCS_SAPDOC01_0101 -w SAAPDB_RCS_SAPDOC01_0101 "C:\\Program Files\\SQL Anywhere 16\\Bin64\\dbsrv16.exe" -n SAAPDB_RCS_SAPDOC01_0101 C:\\SAP\\SAAP\\0101\\db\\0101\\SAAP_RCS.db -n SAAP_RCS_rem_0101 -o C:\\SAP\\SAAP\\0101\\db\\logs\\eng_log_0101 -on 4M -x shmem,tcpip(port=5657) -xs http(port=8080;dbn=SAAP_RCS_rem_0101;MaxRequestSize=10M;log=C:\\SAP\\SAAP\\0101\\db\\logs\\web_log_0101.txt) -gd ALL SQL Anywhere Service Utility Version 16.0.0.2043 Service "SAAPDB_RCS_SAPDOC01_0101" was created successfully.
dbsvc -u SAAPDB_RCS_SAPDOC01_0101 SQL Anywhere Service Utility Version 16.0.0.2043 Service "SAAPDB_RCS_SAPDOC01_0101" start pending. Error starting service "SAAPDB_RCS_SAPDOC01_0101".
I am a SQL Anywhere noob, so not really sure what you meant. Sorry for my ignorance.
I did run this command though:
dbsrv16 -n SAAPDB_RCS_SAPDOC01_0101 C:\\SAP\\SAAP\\db\\0101\\SAAP_RCS.db -n SAAP_RCS_rem_0101 -o C:\\SAP\\SAAP\\db\\logs\\eng_log_0101 -on 4M -x shmem,tcpip(port=5657) -xs http(port=8080;dbn=SAAP_RCS_rem_0101;MaxRequestSize=10M;log=C:\\SAP\\SAAP\\db\\logs\\web_log_0101.txt) -gd ALL . The database has started.
Yes, that's what I was trying to suggest.
Can you now connect to that database successfully (with whatever application you are working...)?
Given the command line is the same as in the DBSVC -w options, and the database engine starts successfully when started manually, it seems that the starting as a service is causing problems here...
Is there anything in the Windows event log? Does starting via command line and "net start SAAPDB_RCS_SAPDOC01_0101" does work - or via the Windows Service MMC?
FWIW, you may also open a new question as the current issue seems different from the original one...
The event viewer logs the information about the failures in the Application logs. That error might be helpful. There will be one or more with SQLANY64 16.0 as the source name.
The only issue that I can identify is that the -o option needs to map to an existing directory structure. And typically the -o option is a path and filename so in you case, -o is trying the directory C:\\SAP\\SAAP\\0101\\db\\logs\\ and will create the file as eng_log_0101. If this is the cause, the application viewer log will contain the error:
SQLANYs_SAAPDB_RCS_SAPDOC01_0101: Can't open Message window log file: C:\\SAP\\SAAP\\0101\\db\\logs\\eng_log_0101
You will also get this error at the command line if you follow Volker's recommendation.
When a dbsrv16 instance was already running in my machine (I started the database from command line instead of service, as per Volker's advice), I tried hitting the dbsrv16 command again.
This time I did get the error: "SQLANYs_SAAPDB_RCS_SAPDOC01_0101: Can't open Message window log file: C:\\SAP\\SAAP\\0101\\db\\logs\\eng_log_0101"
And the same message was reflected in windows event log also.
net start SAAPDB_RCS_SAPDOC01_0101
Sorry, I forgot to mention that SQL Anywhere services by default have the prefix "SQL Anywhere - " before the service name you specify in the dbsvc command (unless you use the -sn option), so you could try
net start "SQL Anywhere - SAAPDB_RCS_SAPDOC01_0101"
That being said, please follow Chris's advice and make sure the file specification behind the -o option belongs to an existing path and includes the file name, too.
Two scenarios:
a. When dbsrv16 is already running:
net start "SQL Anywhere - SAAPDB_RCS_SAPDOC01_0101"
Windows event log: 1.SQLANYs_SAAPDB_RCS_SAPDOC01_0101: Can't open Message window log file: C:\\SAP\\SAAP\\db\\logs\\eng_log_0101 2.SQLANYs_SAAPDB_RCS_SAPDOC01_0101: Could not start server
"C:\\SAP\\SAAP\\db\\logs\\eng_log_0101" is an existing file directory.
b. When I stopped dbsrv16 and ran net start:The SQL Anywhere - SAAPDB_RCS_SAPDOC01_0101 service is starting... The SQL Anywhere - SAAPDB_RCS_SAPDOC01_0101 service was started successfully.
Well, if the database server is already running, the net start command has to fail when it should start a database engine with the same name - there can only be one at a time on the same machine... (In other words: Starting the database as a service is just another way to start it, if it already runs, why then try to start it twice...)
Nevertheless, I think the problem is concealed by the unrecommended usage of -o with a directory instead of a file path...
"C:\\SAP\\SAAP\\db\\logs\\eng_log_0101" is an existing file directory.
What is the contents of that directory?
eng_log_0101
If that is the console log file (doesn't it have a file extension like ".log" or ".txt"???), I would highly recommend to use the -o switch with the full file path, such as
... -o C:\\SAP\\SAAP\\0101\\db\\logs\\eng_log_0101\\eng_log_0101 ...
or better
... -o C:\\SAP\\SAAP\\0101\\db\\logs\\eng_log_0101\\eng_log_0101.txt ...
Note, you can rename the console log of a running database engine via sa_server_option('ConsoleLogFile', <newpathandfilename>);
That means that the database server requires the transaction log and it cannot be found. By default, the database server will create the tranaction log with the same name as the database but with the extension log in the same directory as the database file. This error suggests that the log location is not in the default location.
Run a dblog C:\\SAP\\SAAP\\0101\\db\\0101\\SAAP_RCS.db (replacing the path and datbase name to reflect the database that is reporting this error).
It will report the following output (based on my install of the demo database):
"c:\\sa\\sa16\\Samples\\demo.db" is using log file "demo.log" "c:\\sa\\sa16\\Samples\\demo.db" is using no log mirror file
Make note of the locatoin of the log file and mirror file (if transaction log mirrorring is being used). Make sure that the logs can be located in the location referenced. If there is no path, the log should be maintained in the same directory as the database file.
dblog C:\\SAP\\SAAP\\db\\0101\\SAAP_RCS.db
SQL Anywhere Transaction Log Utility Version 16.0.0.2043 "C:\\SAP\\SAAP\\db\\0101\\SAAP_RCS.db" is using log file "SAAP_RCS.log" "C:\\SAP\\SAAP\\db\\0101\\SAAP_RCS.db" is using no log mirror file Transaction log starting offset is 0003857522 Transaction log current relative offset is 0000199555
There's no other file in C:\\SAP\\SAAP\\db\\0101\\ other then SAAP_RCS.db.
So why is there no .log file in that directory?
SQL Anyhwere databases usually consist of (at least) one database file (.db) and one current log file (.log), so a .log file should be there. Have you copied the database from another location, and the .log file is missing?
When a database has been shutdown normally, you can usually delete the .log file and start the database again, and it will create a new log file. However, that seems not possible in your case because the database seems to need some automatic recovery steps, and the log is required for that. - And additionally, as seem to make use of MobiLink, if the SQL Anywhere database acts as a MobiLink client, you mustn't delete a needed transaction log at all, otherwise your synchronization will fail.
Found the issue. So, the SQL Anywhere was acting as a mobilink client. The machine where the mobilink server was running, there the download and upload paths were wrong (-ftr nd -ftru options) and the mobilink client database files were supposed to be downloaded. Now both .db and .log files are properly downloaded in the path "C:\\SAP\\SAAP\\db\\0101\\" and database service has also started.
User | Count |
---|---|
68 | |
8 | |
8 | |
6 | |
6 | |
6 | |
6 | |
6 | |
6 | |
5 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.