22 November 2024

Wordpress - Local installation in Vmware

If you're interested in exploring website design with WordPress, this guide will help you set up a WordPress instance on your local machine with VMware. The technology stack used consists of RHEL, Apache, MySQL, and PHP, although it is not based on a typical LAMP installation.

RHEL 8.5
1. Select Minimal Installation
2. Turn off SELinux
# vi /etc/selinux/config
SELINUX=disabled
3. Set Hostname
# hostnamectl set-hostname <hostname> --static
4. Set local domain name
# vi /etc/hosts
<local.ip>   <local.dns.name>   <local.hostname>
5. Register Red Hat subscription
# subscription-manager register --username <username> --password <password>
/* subscription-manager attach --auto */
/* To check https://access.redhat.com/management/subscriptions/product/RH00798/systems */
6. Install Packages as required
# yum install -y net-tools-2.0-0.52.20160912git.el8.x86_64
# yum install -y telnet
# yum install -y wget
# yum install -y unzip
# yum install -y perl
7. Update System as required
# yum -y update

Apache
1. Install Apache webserver
# yum install -y httpd
2. Start and Enable Apache service
# systemctl start httpd 
# systemctl enable httpd 
3. Open HTTP port
# firewall-cmd --permanent --add-port=80/tcp
# firewall-cmd --reload
# firewall-cmd --list-all

PHP
1. Switch PHP version to 8.2 to support latest Wordpress
# yum module list php
/* yum module switch-to php:8.2 */
# yum module install --all php:8.2
# php -v
# yum install -y php php-mysqlnd php-pdo php-gd
# php -m
2. Tweak PHP parameters as required by Wordpress
# vi /etc/php.ini
max_input_vars = 3000
post_max_size = 36M
3. Reload PHP-FPM service post php configuration
# systemctl restart php-fpm
4. Verify PHP configurations
# echo "<?php phpinfo() ?>" > /var/www/html/phpinfo.php

WordPress
1. Download latest Wordpress
# wget https://wordpress.org/latest.tar.gz
# tar -xvf latest.tar.gz
# cp -rp wordpress /var/www/html/
2. Assign ownership
# cd /var/www/html
# chown -R apache:apache wordpress/
3. Create Apache WordPress VirtualHost file
# vi /etc/httpd/conf.d/wordpress.conf
<VirtualHost *:80>
ServerAdmin admin@localhost
DocumentRoot /var/www/html/wordpress

<Directory "/var/www/html/wordpress">
Options Indexes FollowSymLinks
AllowOverride all
Require all granted
</Directory>

ErrorLog /var/log/httpd/wordpress_error.log
CustomLog /var/log/httpd/wordpress_access.log common
</VirtualHost>
4. Restart Apache service
# systemctl restart httpd

MySQL
1. Download and Install MySQL
# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-community-server-8.0.37-1.el8.x86_64.rpm
# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-community-client-8.0.37-1.el8.x86_64.rpm
# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-community-common-8.0.37-1.el8.x86_64.rpm
# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-community-client-plugins-8.0.37-1.el8.x86_64.rpm
# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-community-libs-8.0.37-1.el8.x86_64.rpm
# wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-community-icu-data-files-8.0.37-1.el8.x86_64.rpm
# rpm -ivh mysql-community-client-plugins-8.0.37-1.el8.x86_64.rpm
# rpm -ivh mysql-community-common-8.0.37-1.el8.x86_64.rpm
# rpm -ivh mysql-community-libs-8.0.37-1.el8.x86_64.rpm
# rpm -ivh mysql-community-client-8.0.37-1.el8.x86_64.rpm
# rpm -ivh mysql-community-icu-data-files-8.0.37-1.el8.x86_64.rpm
# rpm -ivh mysql-community-server-8.0.37-1.el8.x86_64.rpm
2. Secure MySQL installation
# grep 'temporary password' /var/log/mysqld.log
# mysql_secure_installation
> Enter temporary password
> Enter New password = P@ssw0rd123
> Change the password for root ? ((Press y|Y for Yes, any other key for No) : Y
> Enter New password = P@ssw0rd123
> Remove anonymous users? (Press y|Y for Yes, any other key for No) : Y
> Disallow root login remotely? (Press y|Y for Yes, any other key for No) : Y
> Reload privilege tables now? (Press y|Y for Yes, any other key for No) : Y
3. MySQL version
# mysql --version
4. Start and Enable MySQL service
# systemctl start mysqld
# systemctl enable mysqld
5. Create Wordpress database
# mysql -u root -p
mysql> create database wordpress;
mysql> CREATE USER 'wpadmin'@'localhost' IDENTIFIED WITH mysql_native_password BY 'P@ssw0rd123';
mysql> GRANT ALL PRIVILEGES ON wordpress.* TO 'wpadmin'@'localhost';
mysql> FLUSH PRIVILEGES;
mysql> SELECT * FROM mysql.user;
mysql> exit
6. Verify access via localhost
# mysql -h localhost -u root -p
7. Tweak MySQL parameters as required by Wordpress
# vi /etc/my.cnf
transaction-isolation=READ-COMMITTED
init_connect = "set session autocommit=0"
character-set-server = utf8
8. Restart MySQL service post configuration change
# systemctl restart mysqld

Complete Wordpress installation
Browse http://<local.dns.name>
Follow the installation guide
Create and update wp-config.php as per the instructions


20 February 2018

APACHE - failed to start

[On]
Red Hat Enterprise Linux Server release 7.4 (Maipo)

Apache was not running and attempt to start the httpd service failed. The natural thing as a sysadmin you would check the error_log. 

# systemctl restart httpd
# tail -f /var/log/httpd/error_log (location could be different on your installation)
--- error snippet---
[Tue Feb 20 17:57:32.667940 2018] [auth_digest:error] [pid 6256] (28)No space left on device: AH01762: Failed to create shared memory segment on file /run/httpd/authdigest_shm.6256
[Tue Feb 20 17:57:32.667948 2018] [auth_digest:error] [pid 6256] (28)No space left on device: AH01760: failed to initialize shm - all nonce-count checking, one-time nonces, and MD5-sess algorithm disabled
--- error snippet---

2 things to observe here. 
  1. no space left of device
  2. failed to create shared memory
As it turns out /run partition was used up 100% - which explains the subsequent error -  no. 2. 

Basically - the issue here is Apache has been leaving some stuff behind in shared memory. So the next command list those stuffs 

# ipcs -s (s is semaphores)

--- output ---
------ Semaphore Arrays --------
key        semid      owner      perms      nsems
0x00000000 3375104    apache     600        1
0x00000000 3407873    apache     600        1
0x00000000 2359298    apache     600        1
0x00000000 3440643    apache     600        1
0x00000000 3473412    apache     600        1
0x00000000 3506181    apache     600        1
--- output ---

You may proceed to remove the semaphores (apache only) by executing this command
# ipcrm -s  {semid} (if possible one after another)

Then proceed with restarting the httpd service
# systemctl restart httpd
# systemctl status httpd (verify Apache is running)
# ipcs -s (verify the semaphores are cleared)

Also, it is a good practice to reboot your machine once in 2 or 3 months that will actually clear the unused semaphores. 

19 February 2018

PostgreSQL - Step by step guide installation from source

[Tested On]
CentOS Linux release 7.4.1708 (Core)

# wget https://ftp.postgresql.org/pub/source/v9.6.6/postgresql-9.6.6.tar.gz
# tar xvzf postgresql-9.6.6.tar.gz
# cd postgresql-9.6.6
# mkdir /opt/postgresql-9.6.6
# ./configure --prefix=/opt/postgresql-9.6.6
--- possible error output ---
configure: error: readline library not found
--- possible error output ---
# yum install readline-devel (install the missing library as reported above)
# make
# make install
# adduser postgres
# passwd postgres (set password)
# mkdir /opt/postgresql-9.6.6/data
# chown postgres:postgres /opt/postgresql-9.6.6/data
# su - postgres
$ /opt/postgresql-9.6.6/bin/initdb -D /opt/postgresql-9.6.6/data/
$ /opt/postgresql-9.6.6/bin/postmaster -D /opt/postgresql-9.6.6/data >/opt/postgresql-9.6.6/data/log 2>&1 &
$ ps -eaf | grep postgres (verify postgres is running)
$ vi ~/.bashrc
export PATH=$PATH:/opt/postgresql-9.6.6/bin
-- Save the file
-- Exit to root

--- Start and Stop postgresql using systemctl (systemd) ---
# cd /usr/lib/systemd/system
# vi postgres.service

--- Insert the following script  (change the postgresql location paths accordingly) ---
# START SCRIPT
[Unit]
Description=PostgreSQL database server
After=network.target

[Service]
Type=forking

User=postgres
Group=postgres

# Where to send early-startup messages from the server (before the logging
# options of postgresql.conf take effect)
# This is normally controlled by the global default set by systemd
# StandardOutput=syslog

# Disable OOM kill on the postmaster
OOMScoreAdjust=-1000
# ... but allow it still to be effective for child processes
# (note that these settings are ignored by Postgres releases before 9.5)
Environment=PG_OOM_ADJUST_FILE=/proc/self/oom_score_adj
Environment=PG_OOM_ADJUST_VALUE=0

# Maximum number of seconds pg_ctl will wait for postgres to start.  Note that
# PGSTARTTIMEOUT should be less than TimeoutSec value.
Environment=PGSTARTTIMEOUT=270

Environment=PGDATA=/opt/postgresql-9.6.6/data


ExecStart=/opt/postgresql-9.6.6//bin/pg_ctl start -D ${PGDATA} -s -w -t ${PGSTARTTIMEOUT}
ExecStop=/opt/postgresql-9.6.6/bin/pg_ctl stop -D ${PGDATA} -s -m fast
ExecReload=/opt/postgresql-9.6.6/bin/pg_ctl reload -D ${PGDATA} -s

# Give a reasonable amount of time for the server to start up/shut down.
# Ideally, the timeout for starting PostgreSQL server should be handled more
# nicely by pg_ctl in ExecStart, so keep its timeout smaller than this value.
TimeoutSec=300

[Install]
WantedBy=multi-user.target
# END SCRIPT

--- Save the file

# systemctl daemon-reload
# systemctl enable postgres
# systemctl start postgres

--- Verify postgres is running
# systemctl status postgres

LINUX - Installing a package after a fresh installation

[Tested On]
CentOS Linux release 7.4.1708 (Core) x64


I installed CentOS on my VM with "minimal selection" which later I came to realize that I required cc, gcc and python compilers to install a couple of third party software. 


I performed these steps :

# yum group list

The required compilers are available in the "Development Tools" package which you will find under the Available Groups:

To proceed with the installation, execute the following command:

# yum --setopt=group_package_types=mandatory,default,optional groupinstall "Development Tools"

This will basically install "all" packages under the Development Tools which I prefer to avoid any dependencies issues later on. 

POSTGRESQL - Comparison between PostgreSQL vs EDB Postgres Advanced Server

Your new IT project requires you to setup postgresql database and most of the time we get to the postgresql website and download the version (either the source or rpm files)  and proceed with installation accordingly.

Before you do that, please understand the specific requirement for the database or consult with the project manager before you make a decision to choose either postgresql or EDB Postgresql Advanced Server for your project. 

Please go through the comparison by clicking the link below. 
https://www.enterprisedb.com/products/compare-postgres-databases

LINUX - Delete user account and its home directory

[Tested On]
CentOS Linux release 7.4.1708 (Core)

First please verify user home directory 
# cat /etc/passwd | grep {user}

testuser:x:1001:1002::/home/testuser:/bin/bash

--- /home/testuser - is the user home directory

To delete the user and everything in its home directory, issue the command below

# userdel --remove test





LINUX - Test ping ipv6 address

[Tested On]
Red Hat Enterprise Linux Server release 7.4 (Maipo)

--- Obtain your ipv6 address and network device information
# ifconfig


--- Test ping using ping6
# ping6 {ipv6-address}%{network-device}

Wordpress - Local installation in Vmware

If you're interested in exploring website design with WordPress, this guide will help you set up a WordPress instance on your local mach...