AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / user-680922

mschau's questions

Martin Hope
mschau
Asked: 2024-11-26 21:18:09 +0800 CST

Traefik - filtrar parte da URL

  • 5

Tenho o seguinte cenário: Um Docker Host com vários projetos CMS e um Traefik instalado e funcionando. Gostaria de filtrar a URL de backend de endereços IP públicos, já que ela só deve ser acessível de intervalos de IP privados.

disponível publicamente: https://www.project.com/xyz https://www.project.com/abc

restrito apenas a IPs internos: https://www.project.com/backend

Posso fazer isso com uma lista de permissões de IP e, por exemplo, 2 roteadores - 1 para acesso público e 1 para acesso de backend?

Eu tentei algo como:

  # Backend Router (Restricted Access)
  - "traefik.http.routers.project-backend.rule=Host(`${DOMAINNAME}`) && PathPrefix(`/backend`)"
  - "traefik.http.routers.project-backend.entrypoints=https"
  - "traefik.http.routers.project-backend.tls=true"
  - "traefik.http.routers.project-backend.middlewares=backend-ipwhitelist"
  - "traefik.http.routers.project-backend.priority=100"

Mas o filtro não funcionou - ainda foi possível acessar o backend.

Alguma sugestão?

docker
  • 1 respostas
  • 30 Views
Martin Hope
mschau
Asked: 2024-01-21 16:24:55 +0800 CST

Bitbucket para Gitlab Webhook para acionar pipeline

  • 5

Temos o seguinte cenário local : desenvolvedores trabalhando no Bitbucket em aplicativos, operações trabalhando no Gitlab para coisas "Gitops". Gostaríamos de automatizar compilações e implantações por meio de nosso pipeline Gitlab e procurar maneiras de implementar. A parte de construção já funciona. Mas gostaríamos de distinguir entre filiais - nem todas as filiais deveriam ser implantadas - especialmente a produção seria implantada manualmente.

Como o webhook contém o branch que tentei definir no estágio de implantação:

only:
  - dev

assim como

  rules:
    - if: '$TOKEN_BRANCH != $PROD_BRANCH'

Mas em ambos os sentidos o pipeline de implantação ainda é acionado.

Duas soluções alternativas vieram à minha mente:

Uma opção seria espelhar o repositório bitbucket via "post commit hook" - mas por um lado esse plugin tem custos e por outro lado você precisa de um segundo plugin para o espelhamento - e o único que consigo encontrar não é mantido mais longo.

A segunda opção seria licenciar o Gitlab Ultimate para poder usar o "espelhamento pull", que também poderia ser acionado via webhook do Bitbucket.

Como não temos utilidade no espelhamento de repositório e o único caso de uso seria poder usar o pipeline do Gitlab em um "repositório local" onde todas as maneiras acima de diferenciar o branch para implantação deveriam funcionar - eu preferiria encontrar um maneira com os recursos já disponíveis.

Fico feliz em ouvir sua opinião sobre isso!

EDIT: partes do pipeline:

variables:
  PROD_BRANCH: main

before_script:
  - TOKEN_BRANCH=$(cat $TRIGGER_PAYLOAD | jq -r '.changes[0].ref.displayId')

deploy:
  stage: deploy
  tags:
    - openshift
  rules:
    - if: $TOKEN_BRANCH != $PROD_BRANCH
  • echo $TOKEN_BRANCH retorna "principal".
  • nas regras: esta parte do pipeline só é acionada se a seguinte afirmação for verdadeira.
  • Como "main == main" e não "!=" o estágio "deploy" do pipeline não deve ser executado. Mas isso é...

diversas variantes

rules:
  - if: '$TOKEN_BRANCH !~ $PROD_BRANCH'

rules:
  - if: '$TOKEN_BRANCH =~ $PROD_BRANCH'
    when: never

nesses casos acontece o contrário - o pipeline nunca tem um estágio de implantação - ele nem mostra o estágio na visualização "pipelines" no Gitlab.

gitlab
  • 1 respostas
  • 56 Views

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve