Skip to main content

LINUX How to Control System Processes via SSH

The hearth of each OS are its (apart from the Kernel of course) processes. Linux provides various ways to control the current running processes on the server and we will list a couple of examples to illustrate them. Probably the command you would most often use is the “ps” command which lists all processes based on a certain criteria.
Please note that you can not manipulate the system processes (executing ps, kill, pgrep, top and strace) on the shared server, since your account will not have such privileges.
However, on our dedicated servers you will have root permissions and you will be able to control the system processes.
To list all processes which are started by your user, you can use:
ps x where ps is naturally the command itself and x is the argument we are passing to it.
The result will look like the following one:
PID TTY STAT TIME COMMAND 3735 pts/0 R 0:00 bash 3775 pts/0 R+ 0:00 ps x 5032
? Ss 1:01 wget -mbr --no-passive-ftp….
There are 5 columns in the result, each showing a different set of information. PID shows the process ID number. TTY print the file name of the terminal connected to standard input for that particular process. STAT shows the process state (R means running and S means an interruptible sleep (waiting for an event to complete)).
TIME shows the time the process is running for and COMMAND shows the command itself.
To see the same information (and a bit more) but updated in realtime you can use the following command:
topIn some cases you might need to stop a certain process.
The graceful way to do this is to send a SIGHUP (or SIGTERM) signal to the process and ask it politely to stop itself.
To do this you can use:
kill -15 < pid-ID-number >
or in the above example with the wget process:
kill -15 5032
In some cases however a process can decide to ignore this (graceful) signal.
To kill the process in that case, you can force kill it using:
kill -9 5032
which will send the request directly to the Kernel and cannot be ignored.
A shorter variant of ps with an option to filter the result by process name is “pgrep”.
For example:
pgrep -u root sshd
will only list the processes called sshd and owned (-u argument) by the root user.
Each process will be listed on new line, which allows chaining the commands.
An example of chained commands would be:
strace -p `pgrep -u root sshd`
The above example will run strace command and will attach it to the process (-p argument) returned by the pgrep command.

Comments

Popular posts from this blog

Lambda Function with Amazon SNS

  Amazon SNS is a service used for push notification. In this chapter, we will explain working of AWS Lambda and Amazon SNS with the help of an example where will perform the following actions − Create Topic in SNS Service and use AWS Lambda Add Topics to CloudWatch Send SNS text message on phone number given. Requisites To create Topic in SNS Service and use AWS Lambda Add Topics to CloudWatch, we need not follow the steps given below − Create Topic in SNS Create Role for permission in IAM Create AWS Lambda Function Publish to topic to activate trigger Check the message details in CloudWatch service. To send SNS text message on phone number given, we need to do the following − Add code in AWS Lambda to send message to your phone. Example In this example, we will create a topic in SNS. When details are entered in the topic to publish, AWS Lambda is triggered. The topic details are logged in CloudWatch and a message is sent on phone by AWS Lambda. Here is a basic block diagram which...

Building the Lambda Function

AWS Lambda function executes a code when it is invoked. This chapter discusses all these steps involved in the life cycle of AWS Lambda function in detail. Steps for Building a Lambda function The lifecycle of Lambda function includes four necessary steps − Authoring Deploying Monitoring Troubleshooting Authoring Lambda Code AWS Lambda function code can be written in following languages − NodeJS Java, Python C# Go. We can write code for AWS Lambda using the AWS console, AWS CLI, from Eclipse IDE, from Visual Studio IDE, serverless framework etc. The following table shows a list of languages and the different tools and IDE that can be used to write the Lambda function −   NodeJS :  AWS Lambda Console | Visual Studio IDE Java : Eclipse IDE Python : AWS Lambda Console C# : Visual Studio IDE | .NET core Go : AWS Lambda Console Deploying Lambda Code Once you decide the language you want to write the Lambda function, there are two ways to deploy the code − Directly write the code in...

Lambda Function with Amazon DynamoDB

DynamoDB can trigger AWS Lambda when the data in added to the tables, updated or deleted. In this chapter, we will work on a simple example that will add items to the DynamoDB table and AWS Lambda which will read the data and send mail with the data added. Requisites To use Amazon DB and AWS Lambda, we need to follow the steps as shown below − Create a table in DynamoDB with primary key Create a role which will have permission to work with DynamoDBand AWS Lambda. Create function in AWS Lambda AWS Lambda Trigger to send mail Add data in DynamoDB Let us discuss each of this step in detail. Example We are going to work out on following example which shows the basic interaction between DynamoDB and AWS Lambda. This example will help you to understand the following operations − Creating a table called customer in Dynamodb table and how to enter data in that table. Triggering AWS Lambda function once the data is entered and sending mail using Amazon SES service. The basic block diagram that ...