У меня есть два микросервиса, которые общаются по протоколу http.
AC6K: микросервис C #, который получает данные от устройства Atlas Copco 6000.
LocalWriter: приложение на Python, которое получает данные из AC6K и сохраняетинформация в базе данных
Я проверил ее в средах Windows и Linux, и она отлично работает.Когда я концентрирую каждую микросервисную систему и выполняю развертывание, связь отсутствует.Ниже приведены прилагаемые файлы Docker и yaml, используемые для создания контейнера и развертывания файла приложения
ac6k:
FROM microsoft/aspnetcore-build
EXPOSE 5010
WORKDIR /app
COPY . .
RUN dotnet restore
ENTRYPOINT ["dotnet", "ac6kcore.dll"]
- ac6kUp.yaml
apiVersion: v1
kind: Service
metadata:
name: ac6kcore
labels:
run: ac6kcore
spec:
type: NodePort
ports:
- port: 5010
name: ac6kcore
targetPort: 5010
nodePort: 32766
protocol: TCP
selector:
run: ac6kcore
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: ac6kcore
spec:
selector:
matchLabels:
run: ac6kcore
replicas: 1
template:
metadata:
labels:
run: ac6kcore
spec:
hostNetwork: true
containers:
- image: afierro/ac6kcore:lw
name: ac6kcore
ports:
- containerPort: 5010
restartPolicy: Always
Файл Docker локального писателя:
FROM python:3.6
RUN mkdir -p /mongodbapp
WORKDIR /mongodbapp
COPY requirements.txt /mongodbapp
RUN pip install --no-cache-dir -r requirements.txt
ADD . /mongodbapp
EXPOSE 9090
CMD ["python", "runapp.py"]
- LocalWriter.yaml
apiVersion: v1
kind: Service
metadata:
annotations:
service.alpha.kubernetes.io/tolerate-unready-endpoints: "true"
name: localwriter
labels:
app: localwriter
spec:
type: NodePort
ports:
- port: 9090
name: localwriter
targetPort: 9090
nodePort: 32756
protocol: TCP
selector:
app: localwriter
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: localwriter
spec:
replicas: 1
selector:
matchLabels:
app: localwriter
template:
metadata:
labels:
app: localwriter
spec:
containers:
- name: flasknode
image: afierro/localwriter:v1
imagePullPolicy: Always
ports:
- containerPort: 9090
Заранее спасибо