Why aws cli dont invalidate correctly the cache - AWS Cloudfront












1















I have created a Jenkins job that invalidate the cache each time that my frontend project is deployed. The issue is that although the AWS Website display that the cache is invalidating, when the job finish, the cache isnt completly cleaned, so I need to invalidate it manually through the AWS Website...



The way to invalidate the cache automatically that I used is through aws container where I execute the following command:




  • aws cloudfront create-invalidation --distribution-id ${DISTRIBUTION_ID} --paths /* > output.json


The output file will contain a json where I can get differents keys: values. Two of they that I use is Id and Status. Once the invalidation was created, I another pipeline step I execute the following:




  • aws cloudfront get-invalidation --distribution-id ${DISTRIBUTION_ID} --id ${id_invalidator} > status_invalidation.json


With the previously command I quest to the API each 50 second (through a sleep 50) the status of the invalidation. When the validation return a `Status = Completed', the job is finished. This condition are inside a while loop.



Someone know why this is happened?










share|improve this question























  • I don't see an issue with the approach you are trying. Were you able to confirm that this is happening only for CLI command and not doing it manually via web console for the first time?

    – Ashan
    Nov 23 '18 at 2:12











  • Hi @Ashan ! Thanks for your response. The solution was gived by Michael - sqlbot ! Thanks in all the ways!!

    – Carlos Andres
    Nov 26 '18 at 1:35
















1















I have created a Jenkins job that invalidate the cache each time that my frontend project is deployed. The issue is that although the AWS Website display that the cache is invalidating, when the job finish, the cache isnt completly cleaned, so I need to invalidate it manually through the AWS Website...



The way to invalidate the cache automatically that I used is through aws container where I execute the following command:




  • aws cloudfront create-invalidation --distribution-id ${DISTRIBUTION_ID} --paths /* > output.json


The output file will contain a json where I can get differents keys: values. Two of they that I use is Id and Status. Once the invalidation was created, I another pipeline step I execute the following:




  • aws cloudfront get-invalidation --distribution-id ${DISTRIBUTION_ID} --id ${id_invalidator} > status_invalidation.json


With the previously command I quest to the API each 50 second (through a sleep 50) the status of the invalidation. When the validation return a `Status = Completed', the job is finished. This condition are inside a while loop.



Someone know why this is happened?










share|improve this question























  • I don't see an issue with the approach you are trying. Were you able to confirm that this is happening only for CLI command and not doing it manually via web console for the first time?

    – Ashan
    Nov 23 '18 at 2:12











  • Hi @Ashan ! Thanks for your response. The solution was gived by Michael - sqlbot ! Thanks in all the ways!!

    – Carlos Andres
    Nov 26 '18 at 1:35














1












1








1








I have created a Jenkins job that invalidate the cache each time that my frontend project is deployed. The issue is that although the AWS Website display that the cache is invalidating, when the job finish, the cache isnt completly cleaned, so I need to invalidate it manually through the AWS Website...



The way to invalidate the cache automatically that I used is through aws container where I execute the following command:




  • aws cloudfront create-invalidation --distribution-id ${DISTRIBUTION_ID} --paths /* > output.json


The output file will contain a json where I can get differents keys: values. Two of they that I use is Id and Status. Once the invalidation was created, I another pipeline step I execute the following:




  • aws cloudfront get-invalidation --distribution-id ${DISTRIBUTION_ID} --id ${id_invalidator} > status_invalidation.json


With the previously command I quest to the API each 50 second (through a sleep 50) the status of the invalidation. When the validation return a `Status = Completed', the job is finished. This condition are inside a while loop.



Someone know why this is happened?










share|improve this question














I have created a Jenkins job that invalidate the cache each time that my frontend project is deployed. The issue is that although the AWS Website display that the cache is invalidating, when the job finish, the cache isnt completly cleaned, so I need to invalidate it manually through the AWS Website...



The way to invalidate the cache automatically that I used is through aws container where I execute the following command:




  • aws cloudfront create-invalidation --distribution-id ${DISTRIBUTION_ID} --paths /* > output.json


The output file will contain a json where I can get differents keys: values. Two of they that I use is Id and Status. Once the invalidation was created, I another pipeline step I execute the following:




  • aws cloudfront get-invalidation --distribution-id ${DISTRIBUTION_ID} --id ${id_invalidator} > status_invalidation.json


With the previously command I quest to the API each 50 second (through a sleep 50) the status of the invalidation. When the validation return a `Status = Completed', the job is finished. This condition are inside a while loop.



Someone know why this is happened?







amazon-web-services jenkins amazon-cloudfront pipeline aws-cli






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 22 '18 at 13:41









Carlos AndresCarlos Andres

5012716




5012716













  • I don't see an issue with the approach you are trying. Were you able to confirm that this is happening only for CLI command and not doing it manually via web console for the first time?

    – Ashan
    Nov 23 '18 at 2:12











  • Hi @Ashan ! Thanks for your response. The solution was gived by Michael - sqlbot ! Thanks in all the ways!!

    – Carlos Andres
    Nov 26 '18 at 1:35



















  • I don't see an issue with the approach you are trying. Were you able to confirm that this is happening only for CLI command and not doing it manually via web console for the first time?

    – Ashan
    Nov 23 '18 at 2:12











  • Hi @Ashan ! Thanks for your response. The solution was gived by Michael - sqlbot ! Thanks in all the ways!!

    – Carlos Andres
    Nov 26 '18 at 1:35

















I don't see an issue with the approach you are trying. Were you able to confirm that this is happening only for CLI command and not doing it manually via web console for the first time?

– Ashan
Nov 23 '18 at 2:12





I don't see an issue with the approach you are trying. Were you able to confirm that this is happening only for CLI command and not doing it manually via web console for the first time?

– Ashan
Nov 23 '18 at 2:12













Hi @Ashan ! Thanks for your response. The solution was gived by Michael - sqlbot ! Thanks in all the ways!!

– Carlos Andres
Nov 26 '18 at 1:35





Hi @Ashan ! Thanks for your response. The solution was gived by Michael - sqlbot ! Thanks in all the ways!!

– Carlos Andres
Nov 26 '18 at 1:35












1 Answer
1






active

oldest

votes


















3














You always have to quote expressions with the * character on the command line, to avoid local shell expansion. The correct syntax is this:



--paths '/*'


Otherwise you are trying to invalidate names based on what's in the root directory on your local filesystem (as captured by the *, expanded by the shell).






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',
    autoActivateHeartbeat: false,
    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%2f53432292%2fwhy-aws-cli-dont-invalidate-correctly-the-cache-aws-cloudfront%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









    3














    You always have to quote expressions with the * character on the command line, to avoid local shell expansion. The correct syntax is this:



    --paths '/*'


    Otherwise you are trying to invalidate names based on what's in the root directory on your local filesystem (as captured by the *, expanded by the shell).






    share|improve this answer




























      3














      You always have to quote expressions with the * character on the command line, to avoid local shell expansion. The correct syntax is this:



      --paths '/*'


      Otherwise you are trying to invalidate names based on what's in the root directory on your local filesystem (as captured by the *, expanded by the shell).






      share|improve this answer


























        3












        3








        3







        You always have to quote expressions with the * character on the command line, to avoid local shell expansion. The correct syntax is this:



        --paths '/*'


        Otherwise you are trying to invalidate names based on what's in the root directory on your local filesystem (as captured by the *, expanded by the shell).






        share|improve this answer













        You always have to quote expressions with the * character on the command line, to avoid local shell expansion. The correct syntax is this:



        --paths '/*'


        Otherwise you are trying to invalidate names based on what's in the root directory on your local filesystem (as captured by the *, expanded by the shell).







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 23 '18 at 2:19









        Michael - sqlbotMichael - sqlbot

        92.8k13137199




        92.8k13137199
































            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53432292%2fwhy-aws-cli-dont-invalidate-correctly-the-cache-aws-cloudfront%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

            MongoDB - Not Authorized To Execute Command

            in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

            How to fix TextFormField cause rebuild widget in Flutter