Search code examples
pythonkubernetesodbcopenshiftpyodbc

Installing pyodbc during Openshift Build/Deployment


I am getting an error when installing pyodbc as a part of my Openshift deployment. There are numerous threads explaining the solution, including this one: pip install pyodbc failed ERROR

Error:

Building wheel for pyodbc (setup.py): started
  Building wheel for pyodbc (setup.py): finished with status 'error'
  error: subprocess-exited-with-error
  
  × python setup.py bdist_wheel did not run successfully.
  │ exit code: 1
  ╰─> [10 lines of output]
      running bdist_wheel
      running build
      running build_ext
      building 'pyodbc' extension
      In file included from src/buffer.cpp:12:0:
      src/pyodbc.h:56:17: fatal error: sql.h: No such file or directory
       #include <sql.h>
                       ^
      compilation terminated.
      error: command '/usr/bin/gcc' failed with exit code 1
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
  ERROR: Failed building wheel for pyodbc

My question is: how do I kick off an apt install (or sudo) as a part of my deployment? I am using the OpenShift GUI.

I'm using requirements.txt to force the PIP install of all the dependencies:

pandas
numpy
dash
dash_core_components
dash_html_components
plotly.express
dash
plotly
sqlalchemy
matplotlib
pyodbc
powershift-image

YAML contents for the build:

kind: BuildConfig
apiVersion: build.openshift.io/v1
metadata:
  annotations:
    app.openshift.io/vcs-ref: master
    app.openshift.io/vcs-uri: >-
      ssh://[email protected]_reports.git
    openshift.io/generated-by: OpenShiftWebConsole
  selfLink: >-
    /apis/build.openshift.io/v1/namespaces/ci-testline-analysis-adp/buildconfigs/adp-testline-reports-git
  resourceVersion: '319828205'
  name: adp-testline-reports-git
  uid: 6d2f69e9-8d8d-4c72-bdc0-5838be4649d9
  creationTimestamp: '2022-02-08T18:30:16Z'
  managedFields:
    - manager: Mozilla
      operation: Update
      apiVersion: build.openshift.io/v1
      time: '2022-02-08T20:25:20Z'
      fieldsType: FieldsV1
      fieldsV1:
        'f:metadata':
          'f:annotations':
            .: {}
            'f:app.openshift.io/vcs-ref': {}
            'f:app.openshift.io/vcs-uri': {}
            'f:openshift.io/generated-by': {}
          'f:labels':
            .: {}
            'f:app': {}
            'f:app.kubernetes.io/component': {}
            'f:app.kubernetes.io/instance': {}
            'f:app.kubernetes.io/name': {}
            'f:app.kubernetes.io/part-of': {}
            'f:app.openshift.io/runtime': {}
            'f:app.openshift.io/runtime-version': {}
        'f:spec':
          'f:output':
            'f:to':
              .: {}
              'f:kind': {}
              'f:name': {}
          'f:runPolicy': {}
          'f:source':
            'f:contextDir': {}
            'f:git':
              .: {}
              'f:ref': {}
              'f:uri': {}
            'f:sourceSecret':
              .: {}
              'f:name': {}
            'f:type': {}
          'f:strategy':
            'f:sourceStrategy':
              .: {}
              'f:env': {}
              'f:from':
                .: {}
                'f:kind': {}
                'f:name': {}
                'f:namespace': {}
            'f:type': {}
    - manager: openshift-apiserver
      operation: Update
      apiVersion: build.openshift.io/v1
      time: '2022-02-10T14:04:32Z'
      fieldsType: FieldsV1
      fieldsV1:
        'f:spec':
          'f:triggers': {}
        'f:status':
          'f:lastVersion': {}
  namespace: ci-testline-analysis-adp
  labels:
    app: adp-testline-reports-git
    app.kubernetes.io/component: adp-testline-reports-git
    app.kubernetes.io/instance: adp-testline-reports-git
    app.kubernetes.io/name: python
    app.kubernetes.io/part-of: TestLine-Report
    app.openshift.io/runtime: python
    app.openshift.io/runtime-version: 3.8-ubi7
spec:
  nodeSelector: null
  output:
    to:
      kind: ImageStreamTag
      name: 'adp-testline-reports-git:latest'
  resources: {}
  successfulBuildsHistoryLimit: 5
  failedBuildsHistoryLimit: 5
  strategy:
    type: Source
    sourceStrategy:
      from:
        kind: ImageStreamTag
        namespace: openshift
        name: 'python:3.8-ubi7'
      env:
        - name: APP_FILE
          value: main.py
  postCommit: {}
  source:
    type: Git
    git:
      uri: >-
        ssh://[email protected]_reports.git
      ref: master
    contextDir: /
    sourceSecret:
      name: openshift-key-socialcoding
  triggers:
    - type: Generic
      generic:
        secretReference:
          name: adp-testline-reports-git-generic-webhook-secret
    - type: ImageChange
      imageChange:
        lastTriggeredImageID: >-
          image-registry.openshift-image-registry.svc:5000/openshift/python@sha256:c5d24000000000000000000000
    - type: ConfigChange
  runPolicy: Serial
status:
  lastVersion: 15

Solution

  • To solve my issue, I had to create custom Dockerfile and deploy the application in OpenShift as a Docker image. Specifically, I used add --> from Dockerfile instead of add--> Import from Git (Python builder image) in the GUI. The Import from Git method does not allow enough flexibility to install all of the needed packages. (pyodbc , etc.)