Невозможно запустить контейнер nginx без полномочий root - PullRequest
0 голосов
/ 23 октября 2019

Я пытаюсь запустить контейнер nginx как пользователь без полномочий root. Я пытаюсь настроить мой файл nginx.conf, который я затем помещаю в конфигурационную карту k8s, но когда контейнер запускается, он продолжает выдавать ошибки, такие каккак

директива "pid" здесь не разрешена в /etc/nginx/conf.d/nginx-kibana.conf:4

и для всех последующих

Что мне нужно исправить или настроить в конфигурации, или мне нужно настроить volume: в nginx-deploy.yaml

Это мой nginx.conf

error_log /tmp/error.log;

# The pidfile will be written to /var/run unless this is set.
pid /tmp/nginx.pid;

worker_processes 1;

events {
  worker_connections 1024;
}
http {
  # Set an array of temp and cache file options that will otherwise default to
  # restricted locations accessible only to root.
  client_body_temp_path /tmp/client_body;
  fastcgi_temp_path /tmp/fastcgi_temp;
  proxy_temp_path /tmp/proxy_temp;
  scgi_temp_path /tmp/scgi_temp;
  uwsgi_temp_path /tmp/uwsgi_temp;

  tcp_nopush on;
  tcp_nodelay on;
  keepalive_timeout 65;
  types_hash_max_size 2048;

  include /etc/nginx/mime.types;
  index index.html index.htm index.php;

  default_type application/octet-stream;
  server {
        listen 8080 default_server;
        listen [::]:8080 default_server ipv6only=on;
        server_name  localhost;

        location / {
            root   /usr/share/nginx/html;
            index  index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }

        # the UI will send the request with query string pageId to kibana to load a specific page
        # e.g: iframe src="/kibana/page?pageId=dashboard"
        # set proxy_pass to root kibana does not see the query params, so we have to go to /app/kibana
        location ^~ /${KIBANA_PATH}/page {
          proxy_pass http://127.0.0.1:5601/app/kibana/${ESC}is_args${ESC}args;
          proxy_http_version 1.1;
          proxy_set_header Upgrade ${ESC}http_upgrade;
          proxy_set_header Connection 'upgrade';
          proxy_set_header Host ${ESC}host;
          proxy_cache_bypass ${ESC}http_upgrade;
        }

        # have to re-write URLs for kibana to strip out the /kibana part
        location /${KIBANA_PATH}/ {
          proxy_pass http://127.0.0.1:5601/;
          proxy_http_version 1.1;
          proxy_set_header Upgrade ${ESC}http_upgrade;
          proxy_set_header Connection 'upgrade';
          proxy_set_header Host ${ESC}host;
          proxy_cache_bypass ${ESC}http_upgrade;
        }

    }
}

Вот так я монтирую карту конфигурации в контейнер

      securityContext:
        fsGroup: 2000
        runAsUser: 2000
      volumes:
      - name: nginxconfigmap-volume
        configMap:
          name: my-nginx-configmap

      containers:
      - name: nginx
        image: nginx:stable
        ports:
        - containerPort: 8080
          name: http
          protocol: TCP
        livenessProbe:
          httpGet:
            scheme: HTTP
            path: /
            port: 8080
          initialDelaySeconds: 5
          periodSeconds: 10
          timeoutSeconds: 5
          successThreshold: 1
          failureThreshold: 3
        readinessProbe:
          httpGet:
            scheme: HTTP
            path: /
            port: 8080
          initialDelaySeconds: 5
          periodSeconds: 10
          timeoutSeconds: 5
          successThreshold: 2
          failureThreshold: 6
        volumeMounts:
        - mountPath: /etc/nginx/conf.d
          name: nginxconfigmap-volume

Ответы [ 3 ]

0 голосов
/ 23 октября 2019

Файл nginx.conf идет по пути /etc/nginx, а не /etc/nginx/conf.d. Ошибка, которую вы получаете, связана с nginx, никак не связана с kubernetes. Измените путь для правильной загрузки вашей конфигурации nginx.

0 голосов
/ 24 октября 2019

Проблема решена путем исправления двух вещей. Во-первых, я должен был указать имя файла conf как nginx.conf вместо nginx-kibana.conf

Во-вторых, я должен был указать путь монтирования для mountPath: / etc / nginx

0 голосов
/ 23 октября 2019

Если я изменю путь монтирования тома на

   volumeMounts:
        - mountPath: /etc/nginx
          name: nginxconfigmap-volume

Тогда я получу эту ошибку 2019/10/23 02:50:49 [emerg] 1 # 1: open () "/ etc /nginx / nginx.conf "не удалось (2: нет такого файла или каталога) nginx: [emerg] open ()" /etc/nginx/nginx.conf "не удалось (2: нет такого файла или каталога)

Не знаете, как поступить

...