Use sed to replace IP address with hostname in log output












0















I am trying to replace an IP address in a dnsmasq logfile with its hostname. The logfile is being 'watched' with the command 'tail -f /var/log/dnsmasq.log' on the console and I want to pipe the output into sed to replace the IP address with the hostname on ONLY the lines that contain the text 'query'. The IP address is always at the end of these lines.



An example line is:



Apr  1 00:47:43 dnsmasq[1004]: query[A] gs-loc.apple.com from 10.1.1.188


I believe the command would be in the form of:



tail -f /var/log/dnsmasq.log | sed -e "s/'regex'/$(dig +short -x $1)/g"


The 'regex' needs to identify the lines containing the string "query", extract the IP address from the end of that line and store it (somehow) in a variable - I used the notation $1 here - that is used in the replace expression with dig.



I hope this makes sense. I would be very grateful for any help as the regex is beyond me at the moment.










share|improve this question









New contributor




deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.

























    0















    I am trying to replace an IP address in a dnsmasq logfile with its hostname. The logfile is being 'watched' with the command 'tail -f /var/log/dnsmasq.log' on the console and I want to pipe the output into sed to replace the IP address with the hostname on ONLY the lines that contain the text 'query'. The IP address is always at the end of these lines.



    An example line is:



    Apr  1 00:47:43 dnsmasq[1004]: query[A] gs-loc.apple.com from 10.1.1.188


    I believe the command would be in the form of:



    tail -f /var/log/dnsmasq.log | sed -e "s/'regex'/$(dig +short -x $1)/g"


    The 'regex' needs to identify the lines containing the string "query", extract the IP address from the end of that line and store it (somehow) in a variable - I used the notation $1 here - that is used in the replace expression with dig.



    I hope this makes sense. I would be very grateful for any help as the regex is beyond me at the moment.










    share|improve this question









    New contributor




    deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.























      0












      0








      0








      I am trying to replace an IP address in a dnsmasq logfile with its hostname. The logfile is being 'watched' with the command 'tail -f /var/log/dnsmasq.log' on the console and I want to pipe the output into sed to replace the IP address with the hostname on ONLY the lines that contain the text 'query'. The IP address is always at the end of these lines.



      An example line is:



      Apr  1 00:47:43 dnsmasq[1004]: query[A] gs-loc.apple.com from 10.1.1.188


      I believe the command would be in the form of:



      tail -f /var/log/dnsmasq.log | sed -e "s/'regex'/$(dig +short -x $1)/g"


      The 'regex' needs to identify the lines containing the string "query", extract the IP address from the end of that line and store it (somehow) in a variable - I used the notation $1 here - that is used in the replace expression with dig.



      I hope this makes sense. I would be very grateful for any help as the regex is beyond me at the moment.










      share|improve this question









      New contributor




      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.












      I am trying to replace an IP address in a dnsmasq logfile with its hostname. The logfile is being 'watched' with the command 'tail -f /var/log/dnsmasq.log' on the console and I want to pipe the output into sed to replace the IP address with the hostname on ONLY the lines that contain the text 'query'. The IP address is always at the end of these lines.



      An example line is:



      Apr  1 00:47:43 dnsmasq[1004]: query[A] gs-loc.apple.com from 10.1.1.188


      I believe the command would be in the form of:



      tail -f /var/log/dnsmasq.log | sed -e "s/'regex'/$(dig +short -x $1)/g"


      The 'regex' needs to identify the lines containing the string "query", extract the IP address from the end of that line and store it (somehow) in a variable - I used the notation $1 here - that is used in the replace expression with dig.



      I hope this makes sense. I would be very grateful for any help as the regex is beyond me at the moment.







      sed






      share|improve this question









      New contributor




      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited 17 mins ago









      John1024

      48.2k5113128




      48.2k5113128






      New contributor




      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 23 mins ago









      deanodleydeanodley

      1




      1




      New contributor




      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      deanodley is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          0






          active

          oldest

          votes












          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "106"
          };
          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: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          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
          });


          }
          });






          deanodley is a new contributor. Be nice, and check out our Code of Conduct.










          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f509781%2fuse-sed-to-replace-ip-address-with-hostname-in-log-output%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          deanodley is a new contributor. Be nice, and check out our Code of Conduct.










          draft saved

          draft discarded


















          deanodley is a new contributor. Be nice, and check out our Code of Conduct.













          deanodley is a new contributor. Be nice, and check out our Code of Conduct.












          deanodley is a new contributor. Be nice, and check out our Code of Conduct.
















          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • 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%2funix.stackexchange.com%2fquestions%2f509781%2fuse-sed-to-replace-ip-address-with-hostname-in-log-output%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

          宮崎県

          濃尾地震

          シテ島