Skip to content

This is the 2017 version updated using the things I learned from the 2015 version

License

Notifications You must be signed in to change notification settings

bradchesney79/2017-Debian-Jessie-Secure-WebApp-Server

Repository files navigation

2017-Debian-Jessie-Secure-WebApp-Server

This is the 2017 version updated using the things I learned from the 2015 version

A setup script for a Debian LAMP Webserver for learning concepts. Building with a security focus & geared towards higher performance than stock configuration that should run well everywhere-- considering that if we dumped all this shenanigans on a stock host it would possibly get bogged down. This is mostly to show relationships and it would probably be fine as a guide to set up a proof of concept or development environment.

For instance-- your ORM generated code would likely point at a database not on the same machine. If you are going to take the time to separate anything-- put your database on a second machine. Next is your "in memory" cache service.

My ultimate goal is to use this project to learn and teach end to end tools from system administration to back end infrastructure to front end web client resources.

Initially this will be in implemented with bash until I arrive at an end result I am happy with.

I will use the bash script as a roadmap to build an Ansible playbook.

Bear in mind this is very much "in progress".

How to use this on a very basic level:

#1 Start up a blank linode, initially provision it with Debian 8.1

(If you are a new VPS person one way or another to linode and want to do me a solid, this is my referral code, 47a784faf04635f5f0cc532168f534fdde765000. Thanks.)

#2 SSH into the machine

#3 cut/paste time:

We are supplying a user agent string as Chrome on Linux. Think about someone conditionally supplying content based on the information you are giving to the remote host. By behaving and appearing as a web browser we will get treated like a web browser-- which is our intended goal. We just want to appear to be merely browsing the source code.

curl -A "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36" https://raw.githubusercontent.com/bradchesney79/2017-Debian-Jessie-Secure-WebApp-Server/master/init.sh | sh

#4 set up a junk email service, I reccomend http://33mail.com -- they even have a configuration for people like us in the works

#5 edit setup.conf with your hosts' particulars

You can almost use it as it is, if you just want to see it go, but you'll need to edit a few things:

IPV4=

IPV6=

TARGETEMAIL=

What is my linode IP?

#6 then cut/paste this in the command line to run these two scripts:

. /root/bin/build-script.sh && . /root/bin/load-script.sh

#7 you can hit the host by navigating to the IP address with your browser at the very least (or your domain name if setup)

TODO:

improve install instructions

limit DB permissions taking into consideration constraints introduced by ORM usage -- right now ORM can read/write all app data in the DB

improve troubleshooting resources

remedy broken GUI SFTP -- works fine CLI (might be the ciphers Filezilla is trying to use aren't as strong as the config file whitelist...)

update troubleshooting resources on github

break into modular Ansible scripts

NICE TO HAVE:

disk partitions

SIMILAR PROJECTS:

https://github.com/bogdanvlviv/i-vagrant

THANKS:

simplified logging - http://reddit.com/user/cheaphomemadeacid

reminder that my instructions sucked - https://www.reddit.com/user/iAMthePRONY

reevaluation of sshd MaxStartups - petn-randall: freenode/#debian || irc.debian.org/#debian

MariaDB vs. MySQL 5.7 - blast007: irc.debian.org/#debian MariaDB vs. MySQL 5.7 - tjis: irc.debian.org/#debian

For me to test the whole thing as-is:

linode rebuild rust-belt-rebellion --distribution "Debian 8" --password "ffff4444"; printf 'curl https://raw.githubusercontent.com/bradchesney79/2017-Debian-Jessie-Secure-WebApp-Server/master/init.sh | /bin/bash && cd /root/bin && . /root/bin/build-script.sh'

curl https://raw.githubusercontent.com/bradchesney79/2017-Debian-Jessie-Secure-WebApp-Server/master/init.sh | /bin/bash && cd /root/bin && . /root/bin/build-script.sh && . /root/bin/load-script.sh

About

This is the 2017 version updated using the things I learned from the 2015 version

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages