jueves, 23 de noviembre de 2017

Instalación de Apache Tomcat en Centos 7 y Debian


1.- Actualización del Sistema
Centos7 
yum update

Debian
apt update

2.- Instalación de Java

En el siguiente paso debemos realizar la instalación de Java para que Apache Tomcat pueda ejecutar todas aquellas aplicaciones basadas en Java. 

Para realizar este paso de instalación usaremos el siguiente comando:

Centos7
yum install java-1.8.0-openjdk-devel

El paquete java-1.8.0-openjdk contiene solo Java Runtime Environment. Si desea desarrollar programas Java, instale el paquete java-1.8.0-openjdk-devel.


Debian
apt install openjdk-8-jdk

El paquete openjdk-8-jre contiene solo Java Runtime Environment. Si desea desarrollar programas Java, instale el paquete openjdk-8-jdk.

Nota: Ahora procedemos aceptar la descarga y posteriormente esperamos que la misma sea instalada. 

Por defecto la ruta y el directorio donde se ha instalado Java es /usr/lib/jvm/jre, debemos tomarlo en cuenta para la configuración de Apache Tomcat.

3.- Creación de usuario para Tomcat

Una vez que se instala Java de manera correcta, procedemos a realizar la creación de un usuario que gestionara todo lo relacionado con Apache Tomcat (ESTE USUARIO NO PUEDE SER ROOT)

Primero creamos el grupo
sudo groupadd tomcat

Ahora procedemos a crear el usuario tomcat y añadiremos los siguientes ajustes a dicho usuario:

-Primero hacerlo miembro del grupo tomcat
-Crearemos un directorio en la ruta opt/tomcat (Es donde se instalara Apache Tomcat)
-Agregaremos el parametro /bin/false (Con esto nadie accedera a la cuenta)

Luego procedemos a ejecutar el comando 
sudo useradd -M -s /bin/nologin -g tomcat -d /opt/tomcat tomcat

Una vez realizado este paso podemos descargar e instalar Apache Tomcat 

4.- Descarga e Instalación de Tomcat

Entramos en home para luego iniciar la descarga en ese directorio

cd ~

Posteriormente instalamos el paquete wget y luego iniciamos la descarga de tomcat desde el siguiente link

Link de descarga -> http://www-us.apache.org/dist/tomcat/tomcat-8/v8.5.23/bin/apache-tomcat-8.5.23.tar.gz

Centos7
yum install wget

Debian
apt install wget

wget http://www-us.apache.org/dist/tomcat/tomcat-8/v8.5.23/bin/apache-tomcat-8.5.23.tar.gz

Esperamos unos minutos que la descarga concluya y sea instalada de manera correcta.

Como lo mencionamos anteriormente vamos a instalar Apache Tomcat 8 en la ruta /opt/tomcat pero por defecto esta ruta no existe, para crearla debemos usar el siguiente comando

sudo mkdir /opt/tomcat

Una vez creado el directorio /opt/tomcat procedemos a extraer el archivo que descargamos .tar.gz en la ruta /opt/tomcat con el uso del siguiente comando

sudo tar xvf apache-tomcat-8*tar.gz -C /opt/tomcat --strip-components=1

Esperamos unos minutos que se extraiga Apache Tomcat en la ruta de /opt/tomcat.
Una vez que se extraigan todos los archivos se procede a la asignación de permisos correspondientes

5.- Actualizar permisos al usuario Tomcat

Con la finalidad de que el usuario tomcat pueda acceder a la ruta de la instalación de Tomcat vamos a realizar el siguiente paso. Debemos ir a la ruta donde se instalaron todos los archivos de Apache Tomcat (/opt/tomcat) usando el siguiente comando

cd /opt/tomcat

Una vez que estamos dentro de la ruta vamos a ingresar los siguientes parametros con la finalidad de conceder los permisos de escritura y lectura en dicha ruta

sudo chgrp -R tomcat conf 
sudo chmod g+rwx conf
sudo chmod g+r conf/*

Finalmente vamos a permitir que el usuario tomcat sea el propietario de los logs de aplicaciones web y demas componentes del archivo conf, para ello ingresamos lo siguiente:

sudo chown -R tomcat webapps/ work/ temp/ logs

Ahora procedemos a instalar el archivo system

6.- Instalar el archivo system

En este paso debemos instalar el archive systemd ya que Apache Tomcat va a correr como un servicio, es por eso que ingresaremos lo siguiente para crear el archivo tomcat.service

Creando el archivo
sudo nano /etc/systemd/system/tomcat.service

Aqui podemos observar que se despliega un archivo en blanco por lo cual debemos agregar lo siguiente:

# Systemd unit file for tomcat
[Unit]
Description=Apache Tomcat Web Application Container
After=syslog.target network.target

[Service]
Type=forking

Environment=JAVA_HOME=/usr/lib/jvm/jre
Environment=CATALINA_PID=/opt/tomcat/temp/tomcat.pid
Environment=CATALINA_HOME=/opt/tomcat
Environment=CATALINA_BASE=/opt/tomcat
Environment='CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC'
Environment='JAVA_OPTS=-Djava.awt.headless=true -Djava.security.egd=file:/dev/./urandom'

ExecStart=/opt/tomcat/bin/startup.sh
ExecStop=/bin/kill -15 $MAINPID

User=tomcat
Group=tomcat

[Install]
WantedBy=multi-user.target


Guardamos los cambios utilizando Ctrl + O y salimos del editor usando Ctrl + X

sudo systemctl daemon-reload

Una vez que se reinicio el servicio iniciamos la hacilitación del tomcat

7.- Habilitar el servicio de Apache Tomcat

Una vez hayamos conluido el proceso anterior vamos a iniciar el servicio de Apache con el siguiente comando

sudo systemctl start tomcat

Luego habilitamos Apache Tomcat usando el siguiente comando

sudo systemctl enable tomcat

Una vez que se inicio el servicio se puede verificar la instalación de Tomcat en el navegador, para ello debemos conocer la dirección IP de nuestra maquina o servidor, en el caso de ser local http://127.0.0.1:8080 o http://localhost:8080

Abrimos el navegador y colocamos lo siguiente

http://IP-Servidor:8080

Como vemos se accede a la pantalla inicial de Apache y a partir de allí gestionar lo que consideremos necesario.


miércoles, 15 de noviembre de 2017

Instalacion de DHCP en Debian 9

Primero procedemos actualizar el sistema
#apt-get update 

Luego procedemos a buscar el paquete del servicio de DHCP en Debian 9
#apt search isc-dhcp

Una vez indentificado el paquete procedemos a instalar el DHCP para el servidor Debian 9
#apt install isc-dhcp-server

El archivo de configuración principal del servidor DHCP es dhcpd.conf, el cual se encuentra en el directorio /etc/dhcp/. 
El archivo de configuración contiene una variedad de comentarios, reflejados por el símbolo hash (#) y todas las demás líneas no comentadas son parámetros del servidor dhcp (las cuales son usadas para las características generales de configuración del demonio dhcpd) o declaraciones, que describen los rangos de IP de red y las direcciones IP u otros valores de red que el servidor puede enviar a los dispositivos del cliente.

Una buena practica es que antes de editar dicho archivo de configuracion se respalde, para esto será necesario crear una copia de seguridad del archivo original ejecutando los siguientes comandos:

#cd /etc/dhcp/dhcpd.conf
#cp /etc/dhcp/dhcpd.conf{,.backup}
#cat /dev/null > /etc/dhcp/dhcpd.conf

Entramos en el archivo dhcpd.conf y configuramos las siguientes lineas
#nano /etc/dhcp/dhcpd.conf

ddns-update-style none;
#Es un número entero que establece el tiempo de conexión predeterminado en segundos
default-lease-time 600;
#Es un número entero que establece el tiempo máximo de conexión, en segundos
max-lease-time 7200;
#Es una verificación booleana, Si es true, el servidor graba una dirección antes de asignar una concesión en esa dirección a un cliente
#ping true;
#La dirección IP o las direcciones de los servidores DNS que pueden usar los clientes
option domain-name-servers 172.27.15.2, 10.72.81.2;
#El nombre del dominio que será otorgado a los clientes para usar
option domain-name "example.com";
#El servidor es autoritario, este servidor DHCP debería enviar mensajes DHCPNAK a clientes que están mal configurado
authorative;
#Envía registros a syslog facility local7
log-facility local7;
#máscara de red 255.255.255.0: Hace referencia a la subred para la red 192.168.0.10
subnet 192.168.0.1 netmask 255.255.255.0 {
Define el rango de direcciones IP que el servidor DHCP otorgará a los equipos
range 192.168.0.10 192.168.0.20;

option subnet-mask 255.255.255.0;
option domain-name-servers 192.168.0.254, 10.128.254.254;
option domain-name “example.com”;
#Define la dirección IP de la puerta de enlace o el punto de salida de la red
option routers 192.168.0.1;
#Indica las direcciones IP de los servidores de servicio de nombres NetBIOS (NBNS) o los servidores de servicios de nombres de Internet de Windows (WINS) que utilizan los protocolos SMB / CIFS para compartir archivos en Windows
option netbios-name-servers 192.168.0.11;
#Es un código sobre cómo los clientes de NetBIOS deben intentar la resolución de nombres
option netbios-node-type 8;
get-lease-hostnames true;
use-host-decl-names true;
default-lease-time 600;
max-lease-time 7200;
}

Allí debemos reemplazar las direcciones IP con las adecuadas según sea el caso. Después de editar el archivo de configuración principal y declarar los propios rangos de IP, debemos abrir el archivo /etc/default/isc-dhcp-server y reemplazar el parámetro INTERFACESv4 con el nombre de la interfaz de red que se configurará para la red:

#nano /etc/default/isc-dhcp-server

ctrl+W colocamos INTERFACESv4

y modificamos INTERFACESv4="enp0s3"

luego guardamos

NOTA: -> Recordemos que este nombre o valor lo obtenemos ejecutando el comando ifconfig. 

Una vez completo este punto ejecutaremos los siguientes comandos para reiniciar y ver el estado de ISC
#systemctl restart isc-dhcp-server
#systemctl status isc-dhcp-server

luego evaluamos el status del servicio
#services isc-dhcp-server status

Una vez configurado los clientes con asignación de ip por DHCP ahora deberían comenzar a recibir las respectivas direcciones IP de parte del servidor dhcp.

NOTA: Como reservar direcciones IP Linux para equipos o servidores en la red

En algunas ocasiones será necesario reservar en el DHCP una dirección IP fija para dispositivos de red especiales de la red, como servidores o equipos especiales.

Para ello debemos usar una declaración con el nombre del host al cual se desea otorgar una dirección IP fija y el Control de acceso a medios (MAC). Esta dirección IP reservada se asignará al cliente cada vez que arranque. Debemos reservar una dirección IP fija desde el rango IP que haya sido declarado para la red en el servidor DHCP. La declaración de la dirección IP fija debe estar incluida en las líneas que han sido definidas para el rango de red, accederemos usando nano:

#nano /etc/dhcp/dhcpd.conf
Debemos añadir lo siguiente:

subnet 192.168.0.1 netmask 255.255.255.0 {
range declarations….

host WIN-SERVER {
  hardware ethernet 00:0c:19:bc:2e:e1;
  fixed-address 192.168.0.12;}
}

Guardamos los cambios
restauramos el servicio ejecutando lo siguiente

#systemctl restart isc-dhcp-server

y de esta manera hemos configurado un servidor DHCP con ISC DHCP en Debian 9.

jueves, 2 de noviembre de 2017

Comando PS en Linux

ps

Muestra una instantánea de los procesos actuales. Esta orden admite opciones de las versiones ps propias de System V (precedidas por un guión), de BSD (sin guiones) y de GNU (precedidas por dos guiones).

Algunas de sus opciones son:

-e visualiza información sobre "todos" los procesos del sistema.

-A idem a la opción -e

-j visualiza información sobre el PGID y SID.

 l visualiza "mucha" información sobre los procesos(difiere a poner el signo menos delante).

-f visualiza los parámetros con los que se levanto el proceso.

-a muestra también los procesos de otros usuarios.

-N niega el efecto de cualquier opción que se haya especificado.

-x muestra procesos que no están controlados por ninguna terminal.

-u pepe visualiza información de los procesos del usuario pepe.


Ejemplos de uso:

ps -u root -N visualiza todos los procesos que no sean del usuario root.

ps -aux visualiza información detallada de todos los procesos.


Ejemplos de salidas del comando ps:

Se ejecuta el comando ps con la opción -l

usuario@Laptop-Debian:~$ ps -l

F S   UID   PID     PPID  C PRI  NI ADDR SZ WCHAN  TTY         TIME    CMD
0 S  1000  3308  3301   0  80   0 -  5861  -                     pts/0    00:00:00 bash
0 R  1000  3902  3308   0  80   0 -  2672  -                     pts/0    00:00:00 ps


F PROCESS FLAGS

   1 bifurcado pero no ejecutado.

   4 tiene privilegios de root.

UID ID de usuario.

PID ID del proceso padre

PPID ID del proceso padre.

PGID ID de grupo de un proceso.

PRI Prioridad del proceso.

NI valor de bondad, más elevado menor prioridad.

VSZ Tamaño de la memoria virtual del proceso en Kb.

RSS Tamaño de la memoria física usada en Kb.

WCHAN para los procesos que esperan o dormidos, enumera el evento que espera.

STAT Estado del proceso:

   R Ejecutable.

   D Interrumpió.

   S Suspendido.

   s Es el proceso líder de la sesión.

   T Detenido.

   Z Zombie.

   N Tiene una prioridad menor que lo normal.

   < Tiene una prioridad mayor que lo normal.

TTY nombre de la terminal a la que esta asociado al proceso.

TIME tiempo que lleva en ejecución.