Graylog is an open-source log management system. Founded by a Texas-based company with the same name, Graylog was formerly called Torch, which began as an open-source project in Hamburg, Germany, in the year 2009.
Graylog centrally captures, stores, and enables real-time search and log analysis against terabytes of machine data from any component in IT infrastructure and applications. The software uses Elasticsearch-based three-tier architecture and scalable storage. Graylog created a niche as a fast, affordable, and viable alternative to Splunk.
Installing Graylog on CentOS 7
1. Pre-setup
Fire up a terminal and enter the following command to set a Hostname.
hostnamectl set-hostname graylog
Update the system.
yum update -y
Install Epel Repository.
yum install epel-release
Install needed packages.
yum install pwgen vim
2. Setup JAVA
Install JAVA.
yum install java-1.8.0-openjdk-headless.x86_64
data:image/s3,"s3://crabby-images/a56e8/a56e842d62e26154c79646aade270d21ed445424" alt="Install JAVA"
Install JAVA
Check the java version.
java -version
data:image/s3,"s3://crabby-images/37efa/37efa506673c2c3edea8d73fa1d5363f67bf39ab" alt="Check Java Version"
Check Java Version
3. Install MongoDB
Create a repository file.
vim /etc/yum.repos.d/mongodb-org.repo
Add the following contents.
[mongodb-org-4.0] name=MongoDB Repository baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.0/x86_64/ gpgcheck=1 enabled=1 gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc
List repo.
yum repolist
Install MongoDB.
yum install mongodb-org
data:image/s3,"s3://crabby-images/911ef/911ef33020edc98221c5dfe2b538b12d9f179a4b" alt="Install Mongo"
Install Mongo
Enable mongo service on system boot.
systemctl enable mongod.service
Start service.
systemctl start mongod.service
Check mongo port.
netstat -tunlp | grep 27017
data:image/s3,"s3://crabby-images/20e96/20e96927421a22827b4c2c7ce0a8a5439500c0c2" alt="Mongo Port"
Mongo Port
4. Installing Elasticsearch
Install the Elastic GPG key.
rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch
Create a repository.
vim /etc/yum.repos.d/elasticsearch.repo
Add the following contents to the file.
[elasticsearch-6.x] name=Elasticsearch repository for 6.x packages baseurl=https://artifacts.elastic.co/packages/oss-6.x/yum gpgcheck=1 gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch enabled=1 autorefresh=1 type=rpm-md
List repositories.
yum repolist
Install the open-source version of Elasticsearch.
yum install elasticsearch-oss
data:image/s3,"s3://crabby-images/89c82/89c82d78b37d2291d5923a999a6c1569cda7929d" alt="Install Elastic Search"
Install Elastic Search
Modify the Elasticsearch configuration file.
Set the cluster name to Graylog and add “action.auto_create_index: false” to the file.
vim /etc/elasticsearch/elasticsearch.yml
data:image/s3,"s3://crabby-images/84f4d/84f4d7630ebf0faed0d23fa38d6d087a30d6f6b7" alt="Configurations Configurations"
Configurations
Save and exit the file. Enable elastic search on system boot.
systemctl enable elasticsearch.service
data:image/s3,"s3://crabby-images/55dc1/55dc1ac9329df5e18ddebf90fa9e680cfd41c67f" alt="Enable Elastic Search On System-boot Enable Elastic Search On System-boot"
Enable Elastic Search On System-boot
Check the status of the service.
systemctl status elasticsearch.service
Start service.
systemctl start elasticsearch.service
Check logs.
tail -f /var/log/elasticsearch/graylog.log
Check elastic search health.
curl -XGET 'http://localhost:9200/_cluster/health?pretty=true'
data:image/s3,"s3://crabby-images/c0e35/c0e359a8bc2ff1e3c20c085df453e63d546ea9e4" alt="Check Elastic Search health"
Check Elastic Search health
5. Installing the Graylog
Setup repository.
rpm -Uvh https://packages.graylog2.org/repo/packages/graylog-3.2-repository_latest.rpm
data:image/s3,"s3://crabby-images/81958/8195822af7dc2cb461918c7d77a2ecacf1cc8d1d" alt="Install Repo"
Install Repo
List repositories.
yum repolist
Install Graylog-server.
yum install graylog-server
data:image/s3,"s3://crabby-images/70a4c/70a4c5e60a4273e1fc1125de3ccef18f57f7285d" alt="Install Graylog"
Install Graylog
6. Configure Graylog
You should now add “password_secret” and “root_password_sha2” to server.conf file.
Generate password_secret.
pwgen -N 1 -s 96
Generate root_password_sha2.
echo -n foss@dan123 | sha256sum
Add generated values to file.
vim /etc/graylog/server/server.conf
data:image/s3,"s3://crabby-images/f1801/f180173a78fec86353fc69d670c718535b240a82" alt="Modified File"
Modified File
Change bind-address.
vim /etc/graylog/server/server.conf
Uncomment the following line.
http_bind_address = 127.0.0.1:9000
Enable service on system boot.
systemctl enable graylog-server.service
Start service.
systemctl start graylog-server.service
Monitor server logs.
tail -f /var/log/graylog-server/server.log
data:image/s3,"s3://crabby-images/632a3/632a303a2c1e85adbe4e137bd2af6082aa46e817" alt="Graylog Server Log"
Graylog Server Log
check Server Port.
netstat -tunlp | grep 9000
data:image/s3,"s3://crabby-images/2908d/2908d5ecf80181bc5edcc2243f9d296c3d4aa5cf" alt="Graylog Server Port"
Graylog Server Port
7. Configuring Nginx reverse proxy with SSL
I. Install and configure Nginx
yum install nginx -y
Enable Nginx on boot.
systemctl enable nginx
Check status.
systemctl status nginx
Start service.
systemctl start nginx
II. Setup DNS record
Then go to your DNS manager and add A record for your server.
A Domain Name Server IP
III. Install and configure SSL with Certbot
Install certbot.
yum install certbot python2-certbot-nginx
There are few ways to get and configure SSL using Certbot, but here is the easiest way. Run the below command to get a certificate and apply it to Nginx.
certbot --nginx
Provide needed information when it asks. e.g., you need to provide email, domain name, etc.
data:image/s3,"s3://crabby-images/7503d/7503d9d369200c10ccc47d36042edf826242babe" alt="Get SSL"
Get SSL
When it asks to redirect all traffic to Https, enter the relevant number.
data:image/s3,"s3://crabby-images/1c29a/1c29adb17ddbd5e2b9006124ec5072924b9dc1f2" alt="HTTPS Redirection"
HTTPS Redirection
IV. Modify Nginx configurations
vim /etc/nginx/nginx.conf
Add the following contents to the Location Blocks.
location / { proxy_set_header Host $http_host; proxy_set_header X-Forwarded-Host $host; proxy_set_header X-Forwarded-Server $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Graylog-Server-URL https://$server_name/; proxy_pass http://127.0.0.1:9000; }
Check Nginx for syntax errors.
nginx -t
Restart Nginx.
systemctl restart nginx
8. Set SELinux policy
setsebool -P httpd_can_network_connect 1
9. Browse using your Domain name
https://graylog.fosslinux.com/
Then you will get the login interface.
data:image/s3,"s3://crabby-images/37b64/37b6405c53b7da852971a470c60b730d6abbb00c" alt="Login Window"
Login Window
Login with username “admin” and root password set inside server.conf. After login, you should see an interface like below.
data:image/s3,"s3://crabby-images/76e0e/76e0e3e51a5c0e94a6ab8ca7a7c3618db3f06476" alt="After Login"
After Login
Now we need to set up the input and push log files to the server.
data:image/s3,"s3://crabby-images/05e89/05e8979e723c89b76e4d1b605724722dc0b3491f" alt="Notification"
Notification
That’s all about the installation and configuration of Graylog with SSL on CentOS. I hope you liked the tutorial.
2 comments
How do i send data from remote client?
My graylog server ip is 192.168.11.30
I can send log from sub-net. How do I send data from 192.168.25.107?
how can i send logs from cisco router to graylog server?