Bind nginx-ingress to static IP Address









up vote
0
down vote

favorite












I want to set up an ingress controller on AWS EKS for several microservices that are accessed from an external system.



The microservices are accessed via virtual host-names like svc1.acme.com, svc2.acme.com, ...



I set up the nginx ingress controller with a helm chart: https://github.com/helm/charts/tree/master/stable/nginx-ingress



My idea was to reserve an Elastic IP Address and bind the nginx-controller to that IP by setting the variable externalIP.



This way I should be able to access the services with a stable wildcard DNS entry *.acme.com --> 54.72.43.19



I can see that the ingress controller service get the externalIP, but the IP is not accessible.



NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
ingress-nginx-ingress-controller LoadBalancer 10.100.45.119 54.72.43.19 80:32104/TCP,443:31771/TCP 1m


Any idea why?



Update:



I installed the ingress controller with this command:




helm install --name ingress -f values.yaml stable/nginx-ingress



Here is the gist for values, the only thing changed from the default is




externalIPs: ["54.72.43.19"]



https://gist.github.com/christianwoehrle/3b136023b1e0085b028a67ca6a0959b7










share|improve this question



















  • 2




    what were other steps u made to configure that ingress controller?
    – aurelius
    Nov 9 at 16:57










  • I might be on the wrong track alltogether. I've read that the aws elb can not have a static ip-address. Perhaps I have to live with dynamic ip addresses and solve that with dns.
    – christian
    Nov 10 at 10:04















up vote
0
down vote

favorite












I want to set up an ingress controller on AWS EKS for several microservices that are accessed from an external system.



The microservices are accessed via virtual host-names like svc1.acme.com, svc2.acme.com, ...



I set up the nginx ingress controller with a helm chart: https://github.com/helm/charts/tree/master/stable/nginx-ingress



My idea was to reserve an Elastic IP Address and bind the nginx-controller to that IP by setting the variable externalIP.



This way I should be able to access the services with a stable wildcard DNS entry *.acme.com --> 54.72.43.19



I can see that the ingress controller service get the externalIP, but the IP is not accessible.



NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
ingress-nginx-ingress-controller LoadBalancer 10.100.45.119 54.72.43.19 80:32104/TCP,443:31771/TCP 1m


Any idea why?



Update:



I installed the ingress controller with this command:




helm install --name ingress -f values.yaml stable/nginx-ingress



Here is the gist for values, the only thing changed from the default is




externalIPs: ["54.72.43.19"]



https://gist.github.com/christianwoehrle/3b136023b1e0085b028a67ca6a0959b7










share|improve this question



















  • 2




    what were other steps u made to configure that ingress controller?
    – aurelius
    Nov 9 at 16:57










  • I might be on the wrong track alltogether. I've read that the aws elb can not have a static ip-address. Perhaps I have to live with dynamic ip addresses and solve that with dns.
    – christian
    Nov 10 at 10:04













up vote
0
down vote

favorite









up vote
0
down vote

favorite











I want to set up an ingress controller on AWS EKS for several microservices that are accessed from an external system.



The microservices are accessed via virtual host-names like svc1.acme.com, svc2.acme.com, ...



I set up the nginx ingress controller with a helm chart: https://github.com/helm/charts/tree/master/stable/nginx-ingress



My idea was to reserve an Elastic IP Address and bind the nginx-controller to that IP by setting the variable externalIP.



This way I should be able to access the services with a stable wildcard DNS entry *.acme.com --> 54.72.43.19



I can see that the ingress controller service get the externalIP, but the IP is not accessible.



NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
ingress-nginx-ingress-controller LoadBalancer 10.100.45.119 54.72.43.19 80:32104/TCP,443:31771/TCP 1m


Any idea why?



Update:



I installed the ingress controller with this command:




helm install --name ingress -f values.yaml stable/nginx-ingress



Here is the gist for values, the only thing changed from the default is




externalIPs: ["54.72.43.19"]



https://gist.github.com/christianwoehrle/3b136023b1e0085b028a67ca6a0959b7










share|improve this question















I want to set up an ingress controller on AWS EKS for several microservices that are accessed from an external system.



The microservices are accessed via virtual host-names like svc1.acme.com, svc2.acme.com, ...



I set up the nginx ingress controller with a helm chart: https://github.com/helm/charts/tree/master/stable/nginx-ingress



My idea was to reserve an Elastic IP Address and bind the nginx-controller to that IP by setting the variable externalIP.



This way I should be able to access the services with a stable wildcard DNS entry *.acme.com --> 54.72.43.19



I can see that the ingress controller service get the externalIP, but the IP is not accessible.



NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
ingress-nginx-ingress-controller LoadBalancer 10.100.45.119 54.72.43.19 80:32104/TCP,443:31771/TCP 1m


Any idea why?



Update:



I installed the ingress controller with this command:




helm install --name ingress -f values.yaml stable/nginx-ingress



Here is the gist for values, the only thing changed from the default is




externalIPs: ["54.72.43.19"]



https://gist.github.com/christianwoehrle/3b136023b1e0085b028a67ca6a0959b7







amazon-web-services kubernetes amazon-eks nginx-ingress






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 10 at 10:03

























asked Nov 9 at 14:13









christian

2,84462239




2,84462239







  • 2




    what were other steps u made to configure that ingress controller?
    – aurelius
    Nov 9 at 16:57










  • I might be on the wrong track alltogether. I've read that the aws elb can not have a static ip-address. Perhaps I have to live with dynamic ip addresses and solve that with dns.
    – christian
    Nov 10 at 10:04













  • 2




    what were other steps u made to configure that ingress controller?
    – aurelius
    Nov 9 at 16:57










  • I might be on the wrong track alltogether. I've read that the aws elb can not have a static ip-address. Perhaps I have to live with dynamic ip addresses and solve that with dns.
    – christian
    Nov 10 at 10:04








2




2




what were other steps u made to configure that ingress controller?
– aurelius
Nov 9 at 16:57




what were other steps u made to configure that ingress controller?
– aurelius
Nov 9 at 16:57












I might be on the wrong track alltogether. I've read that the aws elb can not have a static ip-address. Perhaps I have to live with dynamic ip addresses and solve that with dns.
– christian
Nov 10 at 10:04





I might be on the wrong track alltogether. I've read that the aws elb can not have a static ip-address. Perhaps I have to live with dynamic ip addresses and solve that with dns.
– christian
Nov 10 at 10:04













1 Answer
1






active

oldest

votes

















up vote
0
down vote













Maybe you can achieve that by using a Network Load Balancer (https://docs.aws.amazon.com/elasticloadbalancing/latest/network/introduction.html), that supports fixed IPs, as the backing for your Nginx ingress, eg (https://aws.amazon.com/blogs/opensource/network-load-balancer-support-in-kubernetes-1-9/):



apiVersion: v1
kind: Service
metadata:
name: nginx
namespace: default
labels:
app: nginx
annotations:
service.beta.kubernetes.io/aws-load-balancer-type: "nlb"
spec:
externalTrafficPolicy: Local
ports:
- name: http
port: 80
protocol: TCP
targetPort: 80
selector:
app: nginx
type: LoadBalancer





share|improve this answer




















    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53227358%2fbind-nginx-ingress-to-static-ip-address%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    0
    down vote













    Maybe you can achieve that by using a Network Load Balancer (https://docs.aws.amazon.com/elasticloadbalancing/latest/network/introduction.html), that supports fixed IPs, as the backing for your Nginx ingress, eg (https://aws.amazon.com/blogs/opensource/network-load-balancer-support-in-kubernetes-1-9/):



    apiVersion: v1
    kind: Service
    metadata:
    name: nginx
    namespace: default
    labels:
    app: nginx
    annotations:
    service.beta.kubernetes.io/aws-load-balancer-type: "nlb"
    spec:
    externalTrafficPolicy: Local
    ports:
    - name: http
    port: 80
    protocol: TCP
    targetPort: 80
    selector:
    app: nginx
    type: LoadBalancer





    share|improve this answer
























      up vote
      0
      down vote













      Maybe you can achieve that by using a Network Load Balancer (https://docs.aws.amazon.com/elasticloadbalancing/latest/network/introduction.html), that supports fixed IPs, as the backing for your Nginx ingress, eg (https://aws.amazon.com/blogs/opensource/network-load-balancer-support-in-kubernetes-1-9/):



      apiVersion: v1
      kind: Service
      metadata:
      name: nginx
      namespace: default
      labels:
      app: nginx
      annotations:
      service.beta.kubernetes.io/aws-load-balancer-type: "nlb"
      spec:
      externalTrafficPolicy: Local
      ports:
      - name: http
      port: 80
      protocol: TCP
      targetPort: 80
      selector:
      app: nginx
      type: LoadBalancer





      share|improve this answer






















        up vote
        0
        down vote










        up vote
        0
        down vote









        Maybe you can achieve that by using a Network Load Balancer (https://docs.aws.amazon.com/elasticloadbalancing/latest/network/introduction.html), that supports fixed IPs, as the backing for your Nginx ingress, eg (https://aws.amazon.com/blogs/opensource/network-load-balancer-support-in-kubernetes-1-9/):



        apiVersion: v1
        kind: Service
        metadata:
        name: nginx
        namespace: default
        labels:
        app: nginx
        annotations:
        service.beta.kubernetes.io/aws-load-balancer-type: "nlb"
        spec:
        externalTrafficPolicy: Local
        ports:
        - name: http
        port: 80
        protocol: TCP
        targetPort: 80
        selector:
        app: nginx
        type: LoadBalancer





        share|improve this answer












        Maybe you can achieve that by using a Network Load Balancer (https://docs.aws.amazon.com/elasticloadbalancing/latest/network/introduction.html), that supports fixed IPs, as the backing for your Nginx ingress, eg (https://aws.amazon.com/blogs/opensource/network-load-balancer-support-in-kubernetes-1-9/):



        apiVersion: v1
        kind: Service
        metadata:
        name: nginx
        namespace: default
        labels:
        app: nginx
        annotations:
        service.beta.kubernetes.io/aws-load-balancer-type: "nlb"
        spec:
        externalTrafficPolicy: Local
        ports:
        - name: http
        port: 80
        protocol: TCP
        targetPort: 80
        selector:
        app: nginx
        type: LoadBalancer






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 14 at 10:31









        Paulo Schreiner

        64057




        64057



























             

            draft saved


            draft discarded















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53227358%2fbind-nginx-ingress-to-static-ip-address%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Use pre created SQLite database for Android project in kotlin

            Darth Vader #20

            Ondo