what equipment is needed to run owncloud server
25games' six team members are spread all over the country. Communication is washed via Skype, Whatsapp, Slack, etc. and for the direction nosotros use calendars, Trello and other tools (run into „One style to manage a squad" – coming next month). Merely what exercise you demand for your data management? Our requirements are: a cheap solution and total command over the way our data is stored. In this blogpost you'll learn how nosotros configured a Raspberry Pi equally our game developer server to meet our needs. Hither'southward the tabular array of contents (hover the pulsating points):
Purchase a Raspberry Pi
Raspberry Model
There are several Raspberry models available – each with it'southward pros and cons:
- Raspberry Pi 3 – for projects and media tasks: comes with WLAN and Bluetooth OnBoard
- Raspberry Pi 2 Modell B – like above but without WLAN and Bluetooth OnBoard
- Raspberry Pi Modell B(+) – automation tasks
- Raspberry Pi Modell A(+) – small power usage, but poor performance
Since our Raspberry is connected via Ethernet there's no WLAN-support needed. With virtually 10$ electricity costs per yr we chose Raspberry Pi 2 Modell B from the list to a higher place, because we think that information technology provides a practiced trade-off between costs and performance.
Boosted equipment
The Raspberry is useless on its own. You require some additional equipment:
- Micro SD Card – we are using a 32GB card like the one linked (less storage for example 16GB is too possible, only nosotros thought more than is ameliorate since the cost difference is not that crucial)
- Power Supply – at that place'south the aforementioned power supply for European sockets here but we use this one considering it seems to take improve references
- Ethernet cable – the Raspberry Pi 2 has no WLAN OnBoard so y'all need an ethernet cablevision (or WLAN-stick) to connect it with your router. We chose to employ a cable instead of a WLAN-stick considering the server needs to be as fast as possible and it's stationary anyways.
- External storage – information technology is recommended to use an external storage for your working data. We bought two 64GB USB-sticks – one is for the working data and the other one is for backups of our DokuWiki. Since ownCloud and SVN are making local copies on each PC of our squad members we thought that – for the outset – it's enough to just make backups of the DokuWiki.
Preperation of your Raspberry Pi
Prepare SD carte du jour
- Download the latest Raspbian-Prototype
- Plug-in your SD card into your PC
- Download Win32 Disk Imager
- Choose the Raspbian-Image (a), select the SD carte's drive letter (b), click „write" (c)
Connect to your Raspberry
- Connect your Raspberry with the Router via an ethernet cable
- Plug-in the written SD carte du jour into your Raspberry
- Place the IP address of your Raspberry by taking a look into the router configuration. There should exist a list of the connected devices somewhere (a detailed description would become beyond the scope of this article)
- Download Putty (SSH customer)
- Open Putty and fill in the identified IP-accost
- Enter Login-information. Username: pi / Password:raspberry
- sudo nano /etc/network/interfaces (open interface configuration)
- Changeiface eth0 inet dhcp to
iface eth0 inet static address 192.168.ten.yy # ip accost in local network not in DHCP-puddle; use something similar 192.168.ane.42... netmask 255.255.255.0 # netmask - usually 255.255.255.0 gateway 192.168.x.z # router's ip-address (mostly 192.168.ane.1 or 192.168.1.254)
Security configuration
If your squad members are spread all over the world like ours, y'all demand to make your services (SVN, ownCloud, DokuWiki) available over the internet. In this section we present the virtually important tasks to protect your server against hacker attacks.
Supersede user pi
Every hacker knows that there'southward always a user „pi" on systems, which run on Raspbian. That's why you lot should replace the user „pi" with another user. To practice so firstly create the new user with ambassador permissions and set up a strong password:
sudo useradd -one thousand newUser -Thou sudo sudo passwd newUser
Reconnect your PC with your Raspberry Pi via SSH, merely login with your newly created user. Now delete the user „pi":
sudo deluser -remove-home pi
Y'all may realize that you need to retype your new user's countersign each time you execute sudo-commands. To avoid this, employ thesu control to switch to the root user. And so you just accept to blazon in the password once:
sudo su
Automated updates
It is important to keep your Raspberry up to date. Apply these commands:
sudo apt-go update sudo apt-become dist-upgrade sudo rpi-update
Afterrpi-update you may need to reboot your system with:
sudo shutdown -r now
For automatic updates install the packages „unattended-upgrades" and „update-notifier-mutual" by executing these commands:
sudo apt-go install unattended-upgrades update-notifier-mutual sudo dpkg-reconfigure -turn unattended-upgrades
Now alter / etc / apt / apt .conf .d / 10periodic to:
sudo nano /etc/apt/apt.conf.d/10periodic
APT::Periodic::Update-Package-Lists "1"; # daily updates APT::Periodic::Download-Upgradeable-Packages "1"; # daily updates APT::Periodic::AutocleanInterval "7"; # delete unused packages weekly APT::Periodic::Unattended-Upgrade "1"; # daily updates
Configure SSH-access
SSH is not optimally configured in the standard configuration. Open:
sudo nano /etc/ssh/sshd_config
Change the port to something over 1023:
Port 5622
Don't allow root-login past changing the line which starts with „PermitRootLogin" to:
PermitRootLogin no
Install the „fail2ban" parcel to prevent brute force attacks confronting your Raspberry:
sudo apt-go install fail2ban
3 wrong logins from a device with a specific IP-accost are causing a block of this address for 10 minutes by default. We inverse these settings by editing the file /etc/fail2ban/jail.conf to:
sudo nano /etc/fail2ban/jail.conf
bantime = 86400 # = ban for 1 day
Then restart fail2ban:
sudo service fail2ban restart
Firewall configuration
Configure your firewall on your Raspberry Pi to:
- Allow all local connections on the loopback interface
- Drop all foreign looking packages
- Have already opened connections
- Allow SSH and HTTPS (port 8443) connections
- Reject all other connections
Use these commands to do so:
echo "Allow all local connections on the loopback interface" sudo iptables -A INPUT -i lo -j Have echo "Drop all strange looking packages" sudo iptables -A INPUT -p tcp ! --syn -m state --state NEW -j Driblet sudo iptables -A INPUT -f -j Drop sudo iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP sudo iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP echo "Accept already opened connections" sudo iptables -A INPUT -thousand state --state ESTABLISHED,RELATED -j Take echo "Permit SSH and HTTPS connections" sudo iptables -A INPUT -p tcp -m land --state NEW -thousand tcp --dport 5600 -j ACCEPT sudo iptables -A INPUT -p tcp -1000 land --country NEW -g tcp --dport 8443 -j Have echo "Reject all other connections" sudo iptables -A INPUT -j Pass up --reject-with icmp-host-prohibited
Usesudo iptables -L to get a listing of the current rules. Be enlightened that the line-A INPUT -j Turn down –reject-with icmp-host-prohibited is always the terminal rule in your iptables! Only open /etc/network/iptables to edit the rule list:
sudo nano /etc/network/iptables
After editing you always demand to salve the current rules:
sudo sh -c "iptables-save > /etc/network/iptables"
To automatically load the rules subsequently restarting your server you have to create a little Pre-Up-Script and insert the following lines:
sudo nano /etc/network/if-pre-up.d/iptables
#!/bin/sh /sbin/iptables-restore /etc/network/iptables
Then make the file executable:
sudo chmod +x /etc/network/if-pre-up.d/iptables
Enable Port Forwarding
If you desire to brand your Apache web server reachable over the net you need to enable port forwarding on your router. The port forwarding settings can be usually found under the firewall department of your router. Simply there'southward no common standard for where the port forwarding configuration page tin be found on the router's spider web interface. Follow this link and wait for your router. At that place you can find a detailed description for how to configure port forwarding for your specific router. Create a new dominion and fill in the grade similar this:
In the example above Apache listens on port 8443 and forwards the packages to the device with the IP-address of 192.168.0.xy where the last octet (represented as „xy" in the image) needs to be replaced by the address of your Raspberry Pi.
Apache with SSL
The apache server is the footing for all our services: SVN, ownCloud and DokuWiki.
Since we don't want to unencryptedly transfer our of import avails, code-files and internal information we configured our Apache server to only have secure SSL connections.
Installation
Install the latest apache server:
sudo apt-get install apache2
For SSL yous need to activate the ssl module:
sudo a2enmod ssl
For SVN nosotros too demand more modules:
sudo apt-go install libapache2-svn sudo a2enmod dav_svn
PHP is needed for the DokuWiki and ownCloud. Install these packages:
sudo apt-get install php sudo apt-get install libapache2-mod-php5 # PHP5 sudo apt-get install libapache2-mod-php7.0 # PHP7
Mayhap yous also need to activate PHP:
sudo a2enmod php5 # PHP5 sudo a2enmod php7.0 # PHP7
Some more packages are required for the ownCloud-Server (you'll be prompted to create a root password for the MySQL-Database):
sudo apt-become install mariadb-server php4-apcu/trusty-backports sudo apt-get install php5-gd php5-json php5-mysql php5-curl sudo apt-get install php5-intl php5-mcrypt php5-imagick sudo apt-get install redis-server php5-redis
Additionally ownCloud needs these modules to be activated:
sudo a2enmod rewrite sudo a2enmod headers sudo a2enmod env sudo a2enmod dir sudo a2enmod mime sudo a2enmod setenvif
ports.conf
Open the file /etc/apache2/ports.conf :
sudo nano /etc/apache2/ports.conf
Delete the whole content of the file and insert:
<IfModule mod_ssl.c> Listen 8443 https </IfModule>
This tells your apache server that it should heed on port 8443 for SSL connections.
Merely why not using the standard port 443 for SSL? That's because especially when you're a non-commercial user, the near internet service providers (ISPs) only allow port forwarding on not-standard ports like 8443 (await at „Enable Port Forwarding" for how to configure port forwarding).
SSL-certificate
Create a private central:
openssl genrsa -out /etc/ssl/private/apache.primal 2048
Create ssl certificate:
openssl req -new -x509 -key /etc/ssl/private/apache.key -days 365 -sha256 -out /etc/ssl/certs/apache.crt
(Expect at „Advanced configurations for your game evolution server" coming in a few months)
Configure site
Open the file /etc/apache2/site-bachelor/default-ssl.conf :
sudo nano /etc/apache2/site-available/default-ssl.conf
For our services information technology is sufficient to only enable 1 site running on port 8443. So you lot only need to change the /etc/apache2/site-available/default-ssl.conf to this:
<VirtualHost *:8443> ServerAdmin webmaster@localhost DocumentRoot path-to-your-certificate-root-dir # modify this ServerName your-domain:8443 # change this SSLEngine on SSLCertificateFile path-to-certificate.crt # change this SSLCertificateKeyFile path-to-certificate.key # change this ServerSignature On CustomLog /var/log/apache2/access.log combined # can be changed if you like LogLevel warn ErrorLog /var/log/apache2/error.log # can exist inverse if you similar # Deny access to root-directory # <Directory /> Order Deny,Allow Deny from all </Directory> # Configuration for your DokuWiki # Allonym /wiki "path-to-wiki" <Directory path-to-wiki> # change this Order deny,allow Allow from all Require all granted </Directory> <LocationMatch "/(data|conf|bin|inc)/"> Order allow,deny Deny from all Satisfy All </LocationMatch> # Configuation for your ownCloud # Allonym /owncloud "path-to-owncloud" # change this <Directory path-to-owncloud> # change this Options +FollowSymlinks AllowOverride All Guild deny,allow Allow from all Require all granted <IfModule mod_dav.c> Dav off </IfModule> SetEnv HOME path-to-owncloud # change this SetEnv HTTP_HOME path-to-owncloud # change this </Directory> # Disallow plain text (HTTP) connections # <IfModule mod_headers.c> Header e'er set Strict-Transport-Security "max-age=15552000; includeSubDomains" </IfModule> </VirtualHost>
Explanations for lines which need to be inverse:
- DocumentRoot: Let's say your wiki is in /var/www/wiki and your ownCloud in /var/www/owncloud, then your DocumentRoot should be set to /var/world wide web/
- ServerName: Type in the domain:port of your server
- SSLCertificateFile: Type in the full path to the .crt-file, which you lot created here
- SSLCertificateKeyFile: Type in the full path to the .central-file, which you created hither
- For each „path-to-wiki" blazon in the full path to your wiki, for instance /var/www/wiki
- For each „path-to-owncloud" blazon in the full path to your owncloud, for instance /var/www/owncloud
- Additionally you tin can modify the paths to the log files, where Apache tracks all accesses and errors. For this, change the paths in the lines that start with „CustomLog" and „ErrorLog„
At present enable the site „default-ssl" (has only to be done in one case):
sudo a2ensite default-ssl
Ever restart Apache after you inverse something in the configuration:
sudo service apache2 restart
SVN-Server
Why did we cull SVN instead of GIT?
- Our experience showed usa that GIT is harder to sympathize, peculiarly for non-programmers
- Only two of the states are effectively irresolute files on the SVN-server, and then merging is not that difficult
- SVN also allows branching
- Whereas at that place are plugins available for Unity and SVN, there are non for GIT
Since this post should merely be about how to set up the SVN-server, we recommend you to follow these links for more than data on how to use SVN on Linux or Windows.
Installation and Setup
Install SVN:
sudo apt-get install subversion
Create a directory where your SVN-repositories will be stored, create a SVN-repo for your game and modify the permissions then that the Apache server can access the files in the repo:
sudo mkdir -p /var/svn # repo-directory sudo svnadmin create /var/svn/game # repo for your game sudo chown -R www-information:www-data /var/svn # right permissions
For remote access you demand to brand Apache SVN-ready: Run across Apache-Installation.
Create SVN-users and permissions
You need to create SVN-Users for all your team members who will employ SVN. Hither'south how to create the kickoff one (don't use this command for calculation further users!):
sudo htpasswd -c /etc/apache2/dav_svn.passwd severin
Forcalculation more SVN-users use the aforementioned command simply remove the-c parameter:
sudo htpasswd /etc/apache2/dav_svn.passwd simon
If you want to apply Unity together with Unity Cloud Build, information technology is recommended to add together a separate SVN-user just with reading permissions:
sudo htpasswd /etc/apache2/dav_svn.passwd unityCloudBuild
To modify the permissions of your users, create an access command file and type in the following:
sudo nano /etc/apache2/svn-admission-control
[groups] teamName = severin, simon # change team-name, add users unity = unityCloudBuild [/] * = r @teamName = rw # alter team-proper name
You may need to enable the authz_svn – module:
sudo a2enmod authz_svn
Configuration – dav_svn.conf
At present your apache-server needs some more than configuration. Open the file /etc/apache2/mods-bachelor/dav_svn.conf :
sudo nano /etc/apache2/mods-available/dav_svn.conf
Insert this:
LoadModule authz_svn_module modules/mod_authz_svn.so <Location /svn> DAV svn SVNParentPath path-to-svn # change this AuthType Basic AuthName "Proper noun" # change this AuthUserFile svn-user-file # change this AuthzSVNAccessFile svn-admission-control-file # modify this Require valid-user SSLRequireSSL </Location>
Explanation for the lines which need to exist changed:
- SVNParentPath: Total path to your SVN-Repositories
- AuthName: Arbitrary proper noun for your SVN-Repos
- AuthUserFile: Full path to your user-file (in our example higher up: /etc/apache2/dav_svn.passwd )
- AuthzSVNAccessFile: Total path to your access control file (in our example above: /etc/apache/svn-access-control )
Lastly restart apache:
sudo service apache2 restart
If the server can't exist restarted and printsNo apache MPM package installed – then install this package:
sudo apt-go install apache2-mpm-prefork
ownCloud
Like Dropbox, ownCloud provides user and group management, version control and synchronization between as many local machines equally needed. This service is especially interesting for all our members who don't have to work with Unity and SVN – mostly for our artists. Surely, they can use SVN if they want to, merely we thought a Dropbox-like service with auto-synchronization is easier to use and considering of that the artists have more fourth dimension for their artistic work.
Installation
The section „Apache – Installation" explains which packages demand to be installed to run ownCloud on an Apache server. Download the latest ownCloud version with the command written below and unpack information technology (replace x.y.z with the latest ownCloud-Version):
sudo wget https://download.owncloud.org/customs/owncloud-x.y.z.tar.bz2 # tar.bz2 tar -xjf owncloud-ten.y.z.tar.bz2 # for tar.bz2
The latest version number tin be constitute here:
Now copy the unpacked directory into the Apache's document root:
sudo cp -r owncloud /var/world wide web/owncloud
In the section „Apache – Configure site" nosotros explain how to modify the file /etc/apache2/sites-bachelor/default-ssl.conf to run ownCloud on Apache with SSL.
Lastly change the ownership of the ownCloud-directory to the webserver'southward user and group:
sudo chown -R world wide web-data:www-information /var/www/owncloud/
Then you can open up the graphical installation wizard via your browser past visiting the URL „https://yourserver:8443/owncloud„.
Installation Sorcerer
Fill in the account information to create a new administrator.
Alarm:Alter the ownCloud's data-path to a path outside of the Apache's root directory (for instance /home/newUser/owncloud-data instead of /var/www/owncloud/information ). Also use MySQL instead of SQLite for performance reasons. Insert the root password and finish the setup:
Security and operation
Stiff directory permissions
Create a new script file:
sudo nano /dwelling house/newUser/Desktop/owncloud_permissions.sh
Insert the script below and change the content of the following variables
- ocpath (ownCloud directory in apache root directory)
- ocdatapath(data-path of your ownCloud)
- htuser(webserver's user)
- htgroup (group of webserver's user):
#!/bin/fustigate ocpath='/var/www/owncloud' # modify this ocdatapath='/home/newUser/owncloud-information' # modify this htuser='www-data' # change this htgroup='www-data' # change this rootuser='root' printf "Creating possible missing Directoriesn" mkdir -p $ocpath/data mkdir -p $ocpath/avails mkdir -p $ocpath/updater printf "chmod Files and Directoriesn" detect ${ocpath}/ -type f -print0 | xargs -0 chmod 0640 find ${ocpath}/ -type d -print0 | xargs -0 chmod 0750 printf "chown Directoriesn" chown -R ${rootuser}:${htgroup} ${ocpath}/ chown -R ${htuser}:${htgroup} ${ocpath}/apps/ chown -R ${htuser}:${htgroup} ${ocpath}/avails/ chown -R ${htuser}:${htgroup} ${ocpath}/config/ chown -R ${htuser}:${htgroup} ${ocdatapath}/ chown -R ${htuser}:${htgroup} ${ocpath}/themes/ chown -R ${htuser}:${htgroup} ${ocpath}/updater/ chmod +10 ${ocpath}/occ printf "chmod/chown .htaccessn" if [ -f ${ocpath}/.htaccess ] then chmod 0644 ${ocpath}/.htaccess chown ${rootuser}:${htgroup} ${ocpath}/.htaccess fi if [ -f ${ocdatapath}/.htaccess ] then chmod 0644 ${ocdatapath}/.htaccess chown ${rootuser}:${htgroup} ${ocdatapath}/.htaccess fi
Lastly you demand to run the script:
sudo /home/newUser/Desktop/owncloud_permissions.sh
Enable HTTP Strict Transport Security
Refuse HTTP connections to ownCloud by inserting the following into /etc/apache2/sites-available/default-ssl.conf :
sudo nano /etc/apache2/sites-available/default-ssl.conf
# <VirtualHost *:8443> # ... <IfModule mod_headers.c> Header always set Strict-Transport-Security "max-age=15552000; includeSubDomains" </IfModule> # ... # </VirtualHost>
Caching
For pocket-size teams like ours, information technology is sufficient to use APCu for local caching and Redis for file locking. To do so, edit /var/www/owncloud/config/config.php :
# $CONFIG = array ( # 'instanceid' => ... # 'passwordsalt' => ... # ... 'memcache.local' => '\OC\Memcache\APCu', 'filelocking.enabled' => truthful, 'memcache.locking' => '\OC\Memcache\Redis', 'redis' => array ( 'host' => 'localhost', 'port' => 6379, 'timeout' => 0.0, ), #);
DokuWiki
We utilize a wiki to shop and share persistent data which won't be changed for at least some months. E.g. we collect important knowledge which has been gained in meetings. Or we collect data about aspects of our game, for example character descriptions, storylines and quests. We want to avoid disruptive text files stored on our ownCloud – everything should be stored on a central and reachable point (more than about this in „One way to manage a team" coming next month).
Installation
The section „Apache – Installation" explains which packages need to be installed to run DokuWiki on an Apache server. Download the latest DokuWiki version from here. You can use WinSCP to copy the downloaded archive onto your Raspberry.
Unpack the archive, copy it into your webspace and change the owner of the directory:
sudo tar -xzvf dokuwiki.tgz sudo mv dokuwiki /var/world wide web/wiki sudo chown -R www-data:world wide web-data /var/www/wiki
Before installing the wiki, consider the security instructions below!
Then just open up https://yourserver:8443/wiki/install.php and follow the steps. Later on the installation process the wiki is reachable at https://yourserver:8443/wiki/doku.php.
Security
Apache
Add together the lines below to your default-ssl.conf to deny access to the directories ‚data', ‚conf', ‚bin', inc' (see „Apache site configuration„):
# <VirtualHost *:8443> # ... # Deny access to root-directory # <Directory /> Order Deny,Allow Deny from all </Directory> # # Configuration for your DokuWiki # # # Allonym /wiki "path-to-wiki" # <Directory path-to-wiki> # Order deny,let # Allow from all # Require all granted # </Directory> <LocationMatch "/(data|conf|bin|inc)/"> Order allow,deny Deny from all Satisfy All </LocationMatch> # ... #</VirtualHost>
Permissions
Utilise these commands to only let the webserver's user be able to write to directories and files:
sudo find /var/world wide web/wiki -type d -exec chmod 700 {} + sudo find /var/www/wiki -type f -exec chmod 600 {} +
Move DokuWiki'south directories
Alert: If you use the installer of the DokuWiki, you need to execute the install.php script first earlier you can go along.
Move the folder /var/www/wiki/data to anywhere exterior of the Apache'southward document root:
sudo mv /var/www/wiki/data /habitation/newUser/data
So yous need to modify the file /var/www/wiki/conf/local.php :
sudo nano /var/www/wiki/local.php
$conf['savedir'] = '/dwelling/newUser/information'; //add this line into /var/www/wiki/conf/local.php
Move the folder/var/www/wiki/conf:
sudo mv /var/www/wiki/conf /home/newUser/conf
Add a new file /var/world wide web/wiki/lib/preload.php with post-obit content:
sudo nano /var/www/wiki/inc/preload.php
<?php // Exercise NOT use a closing php tag. This causes a problem with the feeds, // among other things. For more information on this issue, please meet:due west // http://www.dokuwiki.org/devel:coding_style#php_closing_tags define('DOKU_CONF','/domicile/newUser/conf/'); // no closing '>'!!
Lastly move the folder/var/www/wiki/bin (or delete it if you don't have beat access on your server):
mv /var/www/wiki/bin /home/newUser/bin
Update your DokuWiki
Y'all tin manually update your wiki or install the upgrade plugin which is definitely more comfortable than the transmission solution. Always create a backup of the whole DokuWiki directory before upgrading!
Source: http://25games.net/your-raspberry-pi-as-a-game-developer-server/
0 Response to "what equipment is needed to run owncloud server"
Post a Comment