summary refs log tree commit diff
path: root/synapse/app
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2017-10-02 18:03:59 +0100
committerErik Johnston <erik@matrix.org>2017-10-02 18:03:59 +0100
commitea87cb1ba5f0a2614043be6f4499cfe842b9b8eb (patch)
tree29a985e99ef07db2e2f0d3ec25651802d4ce6abd /synapse/app
parentMove quit_with_error (diff)
downloadsynapse-ea87cb1ba5f0a2614043be6f4499cfe842b9b8eb.tar.xz
Make 'affinity' package optional
Diffstat (limited to 'synapse/app')
-rw-r--r--synapse/app/_base.py15
1 files changed, 14 insertions, 1 deletions
diff --git a/synapse/app/_base.py b/synapse/app/_base.py
index e1ff8f9b7c..cf4730730d 100644
--- a/synapse/app/_base.py
+++ b/synapse/app/_base.py
@@ -12,10 +12,16 @@
 # 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 gc
 import logging
+import sys
+
+try:
+    import affinity
+except:
+    affinity = None
 
-import affinity
 from daemonize import Daemonize
 from synapse.util import PreserveLoggingContext
 from synapse.util.rlimit import change_resource_limit
@@ -78,6 +84,13 @@ def start_reactor(
         with PreserveLoggingContext():
             logger.info("Running")
             if cpu_affinity is not None:
+                if not affinity:
+                    quit_with_error(
+                        "Missing package 'affinity' required for cpu_affinity\n"
+                        "option\n\n"
+                        "Install by running:\n\n"
+                        "   pip install affinity\n\n"
+                    )
                 logger.info("Setting CPU affinity to %s" % cpu_affinity)
                 affinity.set_process_affinity_mask(0, cpu_affinity)
             change_resource_limit(soft_file_limit)