Update Dockerfile

Update Dockerfile to work again.
Add updated FPS script.
Add overlay placeholde directory.
This commit is contained in:
Ari Timonen 2018-04-28 04:53:47 +00:00
parent 655e7fbcd6
commit 4dfd8a3a44
7 changed files with 101 additions and 35 deletions

4
.gitignore vendored
View file

@ -1,2 +1,4 @@
cfg/*.*
overlay/*
!overlay/.placeholder
logs
scripts/data*

View file

@ -2,8 +2,9 @@ FROM ubuntu
RUN dpkg --add-architecture i386 && \
apt-get update && \
apt-get -y install wget lib32gcc1 lib32stdc++6 libcurl3 unzip liblz4-tool
apt-get -y install wget lib32gcc1 lib32stdc++6 libcurl3 unzip liblz4-tool libcurl3:i386 gcc-multilib g++-multilib
# Accept ToS
RUN printf "\n2\n"|apt-get install -y steamcmd
RUN useradd -m steam
@ -29,31 +30,32 @@ RUN mkdir -p ~/.steam/sdk32 && ln -s ~/.steam/steamcmd/linux32/steamclient.so ~/
WORKDIR /home/steam/hlds
# Install NS
RUN wget 'https://www.ensl.org/files/server/ns_dedicated_server_v32.zip'
COPY --chown=steam files/ns.sha /home/steam/hlds
# RUN sha256sum -c ns.sha
RUN unzip ns_dedicated_server_v32.zip
# NS workaround
RUN echo 70 > ns/steam_appid.txt
RUN mv ns/dlls/ns_i386.so ns/dlls/ns.so
WORKDIR /home/steam/hlds/ns
# Copy own configs including bans
ADD --chown=steam cfg/ /home/steam/hlds/ns/
# NS workarounds
RUN echo 70 > steam_appid.txt
RUN mv dlls/ns_i386.so dlls/ns.so
# ENSL package
RUN cp liblist.gam liblist.bak
RUN wget https://github.com/ENSL/ensl-plugin/releases/download/v1.4/ensl_srvpkg-v1.4.zip -O srv.zip
RUN unzip -o srv.zip
# Use seperate server.cfg because autoexec.cfg is unreliable
RUN touch /home/steam/hlds/ns/server.cfg
# Copy own configs including bans
ADD overlay /home/steam/hlds/ns/
COPY entry.sh /home/steam/hlds
USER root
RUN apt-get update && apt-get install -y libcurl3 libcurl3:i386 gcc-multilib g++-multilib
USER steam
RUN chown -R steam:steam /home/steam
WORKDIR /home/steam/hlds
RUN wget https://github.com/ENSL/ensl-plugin/releases/download/v1.3/ensl_srvpkg-v1.3.zip -O srv.zip
RUN unzip srv.zip
# VAC, HLDS, RCON, HLTV
EXPOSE 26900

View file

@ -1 +1,14 @@
# ensl_hlds
# ENSL HLDS Dockerfile.
How to use:
* `make build` to build Docker image
* `make run` to start NS1 server at default port on localhost
* `make stop` to stop the NS1 server
* `make clean` to clean containers and images
Add any custom configs you want to to overlay directory.
Features:
* Basically installs HLDS + NS1 server + ENSL Plugin.
* Also adds log compression with LZ4.
* Optional argument to enable HLTV.

View file

@ -15,3 +15,4 @@ if [ -z $ROTATE_LOGS ]; then
fi
./hlds_run -game ns +maxplayers 32 +log on +map ns_veil +exec ns/server.cfg
bash

0
overlay/.placeholder Normal file
View file

68
scripts/fps.py Executable file
View file

@ -0,0 +1,68 @@
#!/usr/bin/env python3
import rHLDS, yaml, re, time, os, argparse
from bokeh.plotting import figure, output_file, show
from datetime import datetime
def write_data(filename):
# Default port 27015
srv = rHLDS.Console(host=os.environ['RCON_HOST'], port=os.environ['RCON_PORT'], password=os.environ['RCON_PASSWORD'])
srv.connect()
timestamp = time.time()
file1 = open(filename, "a+")
try:
while True:
data = srv.execute("stats")
fps = re.search('(\d+.?\d*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)', data).group(7)
if fps:
file1.write("%d,%s\n" % (time.time(), fps))
print(fps + " ", end='')
time.sleep(5)
except:
pass
file1.close()
srv.disconnect()
# Read data
def read_data(filename):
file1 = open(filename, "r")
fps_time = []
fps_data = []
while True:
line = file1.readline()
if not line: break
time = re.search('(\d+),(\d+).(\d*)', line).group(1)
fps = re.search('(\d+),(\d+)', line).group(2)
if fps and time:
print('time: ' + time)
print('fps: ' + fps)
fps_time.append(datetime.fromtimestamp(int(time)/1000))
fps_data.append(fps)
# output to static HTML file
output_file("%s.html" % filename)
# create a new plot with a title and axis labels
p = figure(title="hlds_linux stats", x_axis_label='time', y_axis_label='FPS')
# add a line renderer with legend and line thickness
p.line(fps_time, fps_data, legend="FPS", line_width=2)
# show the results
show(p)
filename = "data.%d" % time.time()
parser = argparse.ArgumentParser()
parser.add_argument("--file", help="Use the given file")
args = parser.parse_args()
if not args.file:
write_data(filename)
else:
filename = args.file
read_data(filename)

View file

@ -1,20 +0,0 @@
import rHLDS, yaml, re, time, os
# Default port 27015
srv = rHLDS.Console(host=os.environ['RCON_HOST'], port=os.environ['RCON_PORT'], password=os.environ['RCON_PASSWORD'])
# Connect to server
srv.connect()
file1 = open("data.txt", "a+")
while True:
data = srv.execute("stats")
fps = re.search('(\d+.?\d*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)(\d+.?\d*\s*)', data).group(7)
if fps:
file1.write("%d,%s\n" % (time.time(), fps))
time.sleep(10)
file1.close()
srv.disconnect()