Skip to content

Latest commit

 

History

History
210 lines (161 loc) · 10 KB

LFCE_ServiceConfiguration.md

File metadata and controls

210 lines (161 loc) · 10 KB

LFCE: Service Configuration

  1. Implement and configure an HTTP server
  2. Implement and configure time synchronization server
  3. Implement and configure network logging server
  4. Configure a DHCP server
  5. Implement and configure an SMTP service
  6. Implement and configure the HTTP proxy server
  7. Configure host-based and user-based security for a service
  8. Implement and configure a centralized authentication server
  9. Implement and configure a PXE Boot server
  10. Implement and configure an authoritative DNS server

Implement and configure an HTTP server

Implement and configure time synchronization server

Implement and configure network logging server

  • /etc/rsyslog.conf -> Main config file of rsyslog.

  • Uncomment the lines for UDP/TCP to open the port.

  • Use the following format to log messages:

    • facility.severity_level destination (where to store log)

      • facility: is type of process/application generating message, they include auth, cron, daemon, kernel, local0..local7. Using * means all facilities.

      • severity_level: is type of log message: emerg-0, alert-1, crit-2, err-3, warn-4, notice-5, info6, debug-7.

        Using * means all severity levels and none implies no severity level.

      • destination: is either local file or remote rsyslog server (defined in the form of IP:port).

  • Collecting logs from remote hosts:

    • NOTE: that these rules must come before any rules for processing local messages.

      #### RULES ####
      $template RemoteLogs,"/var/log/%HOSTNAME%/test.log"
      *.* ?RemoteLogs #Record messages from all facilities at all severity levels using the RemoteLogs template configuration
      & stop #Stop processing the messages once it is written to a file. If missing the messages will instead be be written to the local files.
    • For more info check: man rsyslog.conf

  • Client config:

    • Edit /etc/rsyslog.conf and add the following:
      *.* @@192.168.100.10:514 # For TCP
      *.* @192.168.100.10:514 # For UDP
    • Check server side for logs in /var/log/$HOSTNAME
    • Make sure that rsyslog service is running.
    • Above setup works fine.

Configure a DHCP server

  • yum install dhcp -> Install it.

  • vim /etc/dhcp/dhcpd.conf -> The main DHCP config file.

  • cp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf -> Take example config file and comment most of it.

  • It will look like this:

    # A slightly different configuration for an internal subnet.
    subnet 192.168.0.0 netmask 255.255.255.0 {
      range 192.168.0.180 192.168.0.190;
      #option domain-name-servers ns1.internal.example.org;
      #option domain-name "internal.example.org";
      option routers 192.168.0.1;
      option broadcast-address 192.168.0.255;
      default-lease-time 600;
      max-lease-time 7200;
    }
  • Add the DHCP service to the firewall and start the daemon.

Implement and configure an SMTP service

  • Enable the Postfix SMTP server for external access:

    • yum install postfix -> Install it first.

    • /etc/postfix/main.cf -> Main config file.

    • postconf -d "inet_interfaces" -> Verify postfix is listening on the network interfaces.

    • postconf -e "inet_interfaces = all" -> If required, enable listening on the network interfaces.

    • postconf -e "mynetworks_style=subnet" -> Enable trusted subnets means: trust all hosts in the same subnet as any interface on your host.

    • systemctl restart postfix -> And restart the service.

    • Try to send an email:

      $ telnet localhost 25
      Trying ::1...
      Connected to localhost.
      Escape character is '^]'.
      220 osboxes.localdomain ESMTP Postfix
      mail from:root
      250 2.1.0 Ok
      rcpt to:root
      250 2.1.5 Ok
      data
      354 End data with <CR><LF>.<CR><LF>
      THIS IS SPARTAAA
      .
      250 2.0.0 Ok: queued as BD9F1180D0629
      quit
      • Verify the mail was received using the mutt command or the mail command.
    • The default Postfix configuration is only marginally secure:

      • There is no SSL/TLS encryption.
      • No spam filtering is enabled by default.
      • The mynetworks_style directive allows for all hosts in the subnet to forward. Luckily, the default setting of the inet_interfaces directive allows only localhosts to connect.
    • For more info check: man /etc/postfix/main.cf

  • Enable dovecot as IMAP server:

    Dovecot is an open-source IMAP and POP3 server for Unix-like operating systems, written primarily with security in mind.

    The primary purpose of Dovecot is to act as mail storage server.

    • Install it: yum install dovecot mutt
    • Edit the following in /etc/dovecot/dovecot.conf:
      protocols = imap pop3 lmtp
      listen = *, ::
    • Ensure dovecot is using the proper storage location for email:
      • Edit /etc/dovecot/conf.d/10-mail.conf:
      mail_location = mbox: ̃/mail:INBOX=/var/spool/mail/%u
    • Restart the service: systemctl restart dovecot
    • Test it: mutt -f imap://[email protected]
    • For more info check: man /etc/dovecot/dovecot.conf
  • Enable/Disable TLS/SSL for IMAP in Dovecot:

    • Edit /etc/dovecot/conf.d/10-ssl.conf and set ssl to the desired state: yes|no|required
    • Generate certificates if missing: bash /usr/share/doc/dovecot-2.2.36/mkcerts.sh
    • systemctl restart dovecot; mutt -f imap://[email protected]
  • Sending email using SMTP Auth (SASL-Simple Authentication and Security Layer) - not sure if needed

  • Using both SASL and TLS in Postfix (SASL type = dovecot) - not sure if needed

    • cd /etc/pki/tls/certs; make postfix.pem
    • postconf -e "smtpd_tls_auth_only = yes"
    • postconf -e "smtpd_tls_security_level = may"
    • postconf -e "smtpd_tls_cert_file = /etc/postfix/postfix.pem"
    • postconf -e "smtpd_tls_key_file = /etc/postfix/postfix.pem"
    • systemctl restart postfix

Implement and configure the HTTP proxy server

  • Squid is a web proxy used by wide range of organizations. It is often used as caching proxy and improving response times and reducing bandwidth usage.

  • yum -y install squid; systemctl start squid -> Install and start it.

  • /etc/squid/squid.conf -> Main config file.

    • squid -k parse -> Check the config file for errors.
  • Add Squid ACLs and open ports:

    • Add to the config file the following after the INSERT keyword:
      acl localnet src 192.168.0.105
      acl Safe_ports port 2153
    • Even though your RFC 1918 local network may already be in the default squid.conf file, explicitly set your current network as an ACL.
  • Block Websites on Squid Proxy:

    touch /etc/squid/blacklisted_sites.acl
    # And add the following:
    .badsite1.com # The proceding dot tells squid to block all referecnes to that sites including www.badsite1, subsite.badsite1.com etc.
    .badsite2.com
    • Edit the config file and add:
      acl bad_urls dstdomain "/etc/squid/blacklisted_sites.acl"
      http_access deny bad_urls
    • Or do it directly for the file:
      # Block http://www.cbc.com and allow http://www.cbc.ca
      acl blockedsite url_regex ˆhttp://.*cbc.com/.*$
      http_access deny blockedsite

Configure host-based and user-based security for a service

Implement and configure a centralized authentication server

Implement and configure a PXE Boot server

  • PXE (Preboot eXecution Environment) Server allows unattended or automated OS installation over the Network.The main benefit of pxe is that we don’t need any bootable drive to boot OS(Operating system) and we do not need to to burn any ISO file into DVD or usb device.

  • Article how to Configure PXE Server: https://www.linuxtechi.com/configure-pxe-installation-server-centos-7/

  • In general don't belive there will be questions for PXE since you need to configure a loot of stuff especially in container setup like on the exam.

Implement and configure an authoritative DNS server

Back to top of the page: ⬆️