Is there a way to have a SQL query run on the servers even after I turn off my computer?
I heard from a coworker that there was and she wanted me to do that. I believe she said it was called a "screen"?
Is a server running in the background in short, yes! MySql is a server, running all the time, unless you install it "on-demand" and run and stop it yourself.
If you find you are experiencing issues using nohup
with mysql
– I found an alternative solution inspired by @dan08's answer on this page, as well as @Node's answer about putting an already running process into the background from another question on SO.
I had found that when trying the suggestion of using nohup mysql...
to 'background' a long-running mysql
command, that the remote MySQL server I was attempting to connect to refused the connection. When running the same mysql
command without prefixing it with nohup
, the connection succeeded and the mysql
command worked as expected.
As such I looked for alternative methods of achieving the same end-result of being able to run a long-running SQL command (or set of SQL commands) without concerns about the process terminating if I disconnected from the shell session or if a networking issue caused a disconnection from the remote server. This research led to the working solution proposed below:
mysql
command as though you would like to run it in the foreground; for example: mysql <options> -h <host> -u <user> -p -e "source
/absolute/path/to/commands.sql" <database name> 2>&1 >
./mysql_output.log
<user>
(this is triggered by the inclusion of the -p
flag in the mysql
command above).mysql
.bg
command to move the currently suspended process into the background, and resume its processing.jobs
command to list the jobs currently running in the shell session (you may only have one job listed if you don't have any other background processes running in the current session). From this list note the job number for mysql
, which will likely be 1
if you only have one job running.disown -h %<job number>
command, thus disown -h %1
(assuming the job number obtained in step #5 above was 1
). This last command is very important, as it disassociates the current shell session from our mysql
process which we have just moved into the background, so that the mysql
process does not get killed when the terminal shell session ends. Without the call to disown
, your mysql
process that is now running in the background could still get killed if your terminal session ends.The above sequence of commands effectively mimics a call to nohup mysql...
by allowing you to move a long-running call to mysql
into the background and not have the process terminated if you close your terminal session or get disconnected from the remote server. If you find that running nohup mysql...
works in your circumstances that is great as it is certainly the easier and quicker approach, but at least in our application/server environment, we were unable to use nohup mysql...
successfully.
The above sequence should also give you more control over executing the mysql
command as you are initially running the command in the foreground; for instance running mysql
in the foreground will allow you to enter your MySQL connection password securely at the MySQL prompt without having to provide the password as plain-text on the command line (which may be an important security consideration in some hosting/server environments, especially shared hosting where passwords entered on the command line would likely end up in log files such as ~/.bash_history or similar). Additionally, running the command in the foreground, will allow you to see and respond to any connection or other errors before the MySQL command gets moved into the background.
Credit must also go @dan08's answer on this page, and to @Node for his answer regarding placing an already running foreground process into the background, for helping inspire the solution proposed here.
Hopefully this proposed solution will help others who find themselves in a similar situation, where running nohup mysql...
does not work as expected.
I prefer this way:
mysql -u <user> -p<pass> -e 'Insert Query Here' &>> query.log & disown
Example:
mysql -u root -pmypassword -e 'UPDATE bigtable SET column = "value";' &>> query.log & disown
-p
&>> query.log
redirects both stdout and stderr into query.log
(use your path), otherwise entire output will be translated into terminal&
runs the command in backgrounddisown
detaches the command from current terminal, if you close the terminal then command won't die after timeoutYou can control the command using
SHOW FULL PROCESSLIST;
Also you can stop it using
KILL [id]; -- get the ID from previous command
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With