Set Up Ubuntu ServerPackage Selection
.bashrcumask 0077 (or 0022 to allow read access for other users) SSH Public Key AuthenticationCopy over the public key, then > mkdir .ssh Packages> dpkg -l Java, Ant, and Maven> sudo apt-get install openjdk-8-jdk
Select OpenJDK 8 to be the default JVM: > sudo update-alternatives --config java Then install Ant and Maven: > sudo apt-get install ant Subversion> sudo apt-get install subversion
> sudo apt-get install xinetd
Create /etc/xinetd.d/svn with the following content: service svn
{ disable = no port = 3690 socket_type = stream protocol = tcp wait = no user = cysun server = /usr/bin/svnserve server_args = -i -r /home/cysun/subversion } then restart xinetd: > sudo /etc/init.d/xinetd restart MySQL and phpMyAdminIf MySQL is not installed already: > sudo apt-get install mysql-server
Log into MySQL and create an account and a database for the user: > mysql -u root -p
mysql> create database cysun;
mysql> grant all privileges on cysun.* to 'cysun'@'%' identified by 'abcd' with grant option;
mysql> flush privileges;
mysql> quit
Note that the GRANT statement will automatically create the user account if it does not exist. Now install phpMyAdmin: > sudo apt-get install phpmyadmin During configuration you'll need to provide the root password of MySQL. After phpMyAdmin is installed, it can be accessed at http://host/phpmyadmin/ . By default MySQL server does not accept remote connections. To enable remote connections (which is necessary for servers like CS3 but not for servers like CSNS), modify /etc/mysql/my.cnf so the following line is commented out: bind-address = 127.0.0.1 then restart the MySQL server: > sudo service mysql restart PostgreSQL and phpPgAdminIf PostgreSQL is not installed already: > sudo apt-get install postgresql Log into PostgreSQL and create an account and a database for the user: > sudo -u postgres psql template1
psql> create user cysun with createdb password 'abcd';
psql> create database cysun with owner=cysun;
psql> \q
Leave out the createdb option in the CREATE USER statement if you do not want to grant the user the privilege to create databases. By default PostgreSQL server does not accept remote connections. To enable remote connections (which is necessary for servers like CS3 but not for servers like CSNS), modify /etc/postgresql/9.1/main/postgresql.conf so: listen_addresses = '*' And modify /etc/postgresql/9.1/main/pg_hba.conf so that: host all all 0.0.0.0/0 md5 To install phpPgAdmin: > sudo apt-get install phppgadmin By default phpPgAdmin only allows local access. To allow remote access, edit /etc/phppgadmin/apache.conf so that #deny from all
#allow from 127.0.0.0/255.0.0.0 ::1/128 allow from all Then restart Apache2. After that phpPgAdmin can be accessed at http://host/phpmyadmin/ . Tomcat> sudo apt-get install tomcat8 Once installed, Tomcat will be running at port 8080. The webapp directory is at /var/lib/tomcat8/webapps/ and the configuration files are under /etc/tomcat8/. On CS3, the instructor of CS3220/5220 may need to restart some applications once in a while, so install the Tomcat Admin package: > sudo apt-get install tomcat8-admin And edit /etc/tomcat8/tomcat-users.xml to add a manager user. Tomcat Manager can be accessed at http://host:8080/manager/html. Install JDBC drivers: > sudo apt-get install libmysql-java
> sudo apt-get install libpg-java
The JAR file will be installed under /usr/share/java with many other JAR files. To make them available to Tomcat, symbolic links to them need to be created under /usr/share/tomcat8/lib: > cd /usr/share/tomcat8/lib
> sudo ln -s ../../java/mysql.jar mysql.jar
> sudo ln -s ../../java/postgresql.jar postgresql.jar
JSTL is still not included in the Tomcat distribution, and there doesn't seems to be a package that provide them, so download it from Apache Jakarta, place jstl.jar and standard.jar under /usr/share/java, then link them from /usr/share/tomcat8/lib like before. ApacheEnable userdir (i.e. public_html): > sudo a2enmod userdir SambaSet the ownership of the directory to be shared to nobody.nogroup: > sudo chown nobody.nogroup /home/cysun/documents Edit /etc/samba/smb.conf:
[documents] Note that the Samba mask is different from umask - 0644 in this case will be the permissions of the files created instead of a "mask" applied to the permissions. Add a Samba user: > sudo smbpasswd -a cysun Note that the user should already have an account on the server; if not, use adduser to create a user account first. And finally: > sudo restart smbd Install postfix and mutt if they are not installed already: > sudo apt-get install postfix Choose Internet Site during the postfix configuration. To add email aliases, edit /etc/aliases then run postalias: > sudo vi /etc/aliases Manual Update> sudo apt-get update Update and Dist UpgradeIf unattended-upgrades is not installed: > sudo apt-get install unattended-upgrades
Edit /etc/apt/apt.conf.d/50unattended-upgrades to enable the following:
Then > sudo service unattended-upgrades restart Edit /etc/update-manager/release-upgrades to change Prompt=lts to Prompt=normal. This would allow do-release-upgrade to upgrade an LTS release to a normal release. OtherEdit /etc/default/useradd and change SHELL to be /bin/bash so the default shell for accounts created with useradd will be bash instead of sh. To disable a service, e.g. apache2: > sudo update-rc.d -f apache2 remove And to enable it: > sudo update-rc.d apache2 defaults |