Usages of following resources are limited(for at least python runtime): - cpu - process number - file descriptor - file size Change-Id: I3bbd9e7a46a970eb0d9e99d1258b7b27407c0d90 Implements: blueprint qinling-container-resource-limitationchanges/98/525098/3
parent
6c013ddb7b
commit
09f5e6dc60
@ -0,0 +1,38 @@
|
||||
# Copyright 2017 Catalyst IT Ltd
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
import resource
|
||||
|
||||
|
||||
def main(number=1024, **kwargs):
|
||||
for name, desc in [
|
||||
('RLIMIT_NOFILE', 'number of open files'),
|
||||
]:
|
||||
limit_num = getattr(resource, name)
|
||||
soft, hard = resource.getrlimit(limit_num)
|
||||
print('Maximum %-25s (%-15s) : %20s %20s' % (desc, name, soft, hard))
|
||||
|
||||
files = []
|
||||
|
||||
try:
|
||||
for i in range(0, number):
|
||||
files.append(_create_file(i))
|
||||
finally:
|
||||
for f in files:
|
||||
f.close()
|
||||
|
||||
|
||||
def _create_file(index):
|
||||
f = open('file_%s' % index, 'w')
|
||||
return f
|
@ -0,0 +1,43 @@
|
||||
# Copyright 2017 Catalyst IT Ltd
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
from multiprocessing import Process
|
||||
import resource
|
||||
import time
|
||||
|
||||
|
||||
def main(number=128, **kwargs):
|
||||
for name, desc in [
|
||||
('RLIMIT_NPROC', 'number of processes'),
|
||||
]:
|
||||
limit_num = getattr(resource, name)
|
||||
soft, hard = resource.getrlimit(limit_num)
|
||||
print('Maximum %-25s (%-15s) : %20s %20s' % (desc, name, soft, hard))
|
||||
|
||||
processes = []
|
||||
|
||||
for i in range(0, number):
|
||||
p = Process(
|
||||
target=_sleep,
|
||||
args=(i,)
|
||||
)
|
||||
p.start()
|
||||
processes.append(p)
|
||||
|
||||
for p in processes:
|
||||
p.join()
|
||||
|
||||
|
||||
def _sleep(index):
|
||||
time.sleep(10)
|
@ -1,13 +1,17 @@
|
||||
FROM phusion/baseimage:0.9.22
|
||||
MAINTAINER lingxian.kong@gmail.com
|
||||
MAINTAINER anlin.kong@gmail.com
|
||||
|
||||
RUN apt-get update
|
||||
RUN apt-get -y install python-dev python-setuptools libffi-dev libxslt1-dev libxml2-dev libyaml-dev libssl-dev python-pip
|
||||
RUN pip install -U pip setuptools
|
||||
USER root
|
||||
RUN useradd -Ms /bin/bash qinling
|
||||
|
||||
RUN apt-get update && \
|
||||
apt-get -y install python-dev python-setuptools libffi-dev libxslt1-dev libxml2-dev libyaml-dev libssl-dev python-pip && \
|
||||
pip install -U pip setuptools
|
||||
|
||||
COPY . /app
|
||||
WORKDIR /app
|
||||
RUN pip install -r requirements.txt
|
||||
RUN pip install -r requirements.txt && \
|
||||
chmod 0750 custom-entrypoint.sh && \
|
||||
chown -R qinling:qinling /app
|
||||
|
||||
ENTRYPOINT ["python", "-u"]
|
||||
CMD ["server.py"]
|
||||
CMD ["/bin/bash", "custom-entrypoint.sh"]
|
||||
|
@ -0,0 +1,18 @@
|
||||
#!/usr/bin/env bash
|
||||
# This is expected to run as root for setting the ulimits
|
||||
|
||||
set -e
|
||||
|
||||
# ensure increased ulimits - for nofile - for the runtime containers
|
||||
# the limit on the number of files that a single process can have open at a time
|
||||
ulimit -n 1024
|
||||
|
||||
# ensure increased ulimits - for nproc - for the runtime containers
|
||||
# the limit on the number of processes
|
||||
ulimit -u 128
|
||||
|
||||
# ensure increased ulimits - for file size - for the runtime containers
|
||||
# the limit on the total file size that a single process can create, 30M
|
||||
ulimit -f 61440
|
||||
|
||||
/sbin/setuser qinling python -u server.py
|
Loading…
Reference in new issue