• r00ty@kbin.life
    link
    fedilink
    arrow-up
    91
    ·
    11 天前

    I have a tool that I wrote, probably 5+ years ago. Runs once a week, collects data from a public API, translates it into files usable by the asterisk phone server.

    I totally forgot about it. Checked. Yep, up to date files created, all seem in the right format.

    Sometimes things just keep working.

    • RustyNova@lemmy.world
      link
      fedilink
      arrow-up
      49
      ·
      11 天前

      Meanwhile, had to debug a script that zipped a zip recursively, with the new data appended. The server had barely enough storage left, as the zip took almost 200GB (the data is only 3GB). I looked at the logs, last successful run: 2019

      • r00ty@kbin.life
        link
        fedilink
        arrow-up
        18
        ·
        11 天前

        Yes, had the same happen. Something that should be simple failing for stupid reasons.

        • RustyNova@lemmy.world
          link
          fedilink
          arrow-up
          13
          ·
          11 天前

          Well it’s not that simple… Because whoever wrote that made it way too complicated (and the production version has been tweaked without updating the dev too)

          A clean rewrite with some guard clauses helped remove the haduken ifs and actually zipping the file outside of the zipped directory helped a lot

          • r00ty@kbin.life
            link
            fedilink
            arrow-up
            7
            ·
            11 天前

            I mean, I have to say I’ve hastened my own demise (in program terms) by over-engineering something that should be simple. Sometimes adding protective guardrails actually causes errors when something changes.

            • Croquette@sh.itjust.works
              link
              fedilink
              arrow-up
              1
              ·
              8 天前

              Which are what guardrails are for. When something change, you don’t know the impact the change will have.

              By having guardrails, you make sure to limit/eliminate potential critical issues.

          • Quantenteilchen@discuss.tchncs.de
            link
            fedilink
            arrow-up
            3
            ·
            11 天前

            Am I understanding that last part correctly?

            […] and actually zipping the file outside of the zipped directory helped a lot

            Did they just automatically create a backup zip-bomb in their script‽

            • RustyNova@lemmy.world
              link
              fedilink
              arrow-up
              8
              ·
              11 天前

              I oversimplified it but the actual process was to zip files to send to an FTP server

              The cron zipped the files to send in the same directory as the zipped files, then sent the zip, then deleted the zip

              Looks fine, right? But what if the FTP server is slow and uploading take more time than the hourly cron dispatch? You now have a second script that zip all the folder, with the previous zip file, which will slow down the upload, etc…

              I believe may have been started by an FTP upload erroring out and forcing an early return without having a cleanup, and progressively got worse

              … I suppose this happened. The logs were actually broken and didn’t actually add the message part of the error object, and only logging the memory address to it

        • RustyNova@lemmy.world
          link
          fedilink
          arrow-up
          14
          ·
          11 天前

          Oh no need. The client didn’t noticed anything in 6 years, and the reason why we had to check is because they wanted us to see if we could add this feature… That already existed.

    • Gonzako@lemmy.world
      link
      fedilink
      arrow-up
      20
      arrow-down
      1
      ·
      11 天前

      Yeah, all these simple data processing scripts will always work as long as both sides stay the same/compatible

  • rumba@lemmy.zip
    link
    fedilink
    English
    arrow-up
    44
    ·
    11 天前

    I don’t see the alias in your .bashrc

    yeah, um, about that. I have no idea where it comes from. We can type alias and see what it is, so if it’s ever lost, we can recreate it, but I looked for 30 minutes yesterday even did a grep -R and I have NO IDEA where it comes from, or why it’s named electricboogaloo

    • cenzorrll@lemmy.ca
      link
      fedilink
      arrow-up
      13
      ·
      edit-2
      11 天前

      Ha, loser.

      *glances over at 6 bash scripts and 2 cron jobs*

      Not you, you’re perfect

    • pinball_wizard@lemmy.zip
      link
      fedilink
      arrow-up
      32
      ·
      11 天前

      Well, here’s a sentence I haven’t been tempted to use before:

      “I believe that may be too many crontab entries.”

    • marcos@lemmy.world
      link
      fedilink
      arrow-up
      5
      ·
      11 天前

      At some point it may be good to migrate to airflow or something similar.

      It’s not the number of entries that makes it bad. It’s the fact that if you run crontab, they are gone…

        • marcos@lemmy.world
          link
          fedilink
          arrow-up
          7
          ·
          11 天前

          Make the rule start a secondary cron system. Otherwise it won’t run after you erase the crontab.

      • bleistift2@sopuli.xyz
        link
        fedilink
        English
        arrow-up
        8
        ·
        edit-2
        11 天前

        At first I thought you missed the -r. Then I checked. Defaulting to STDIN here is very, very dumb, IMHO. Almost as bad as putting the “edit” flag right next to the “delete everything without confirmation” flag on a Western keyboard (-e vs -r).

        • marcos@lemmy.world
          link
          fedilink
          arrow-up
          7
          ·
          11 天前

          Crontab is a really badly designed program that we just can’t fix because everybody depends on its WFTs for something.

    • marcos@lemmy.world
      link
      fedilink
      arrow-up
      4
      ·
      11 天前

      Nobody write down that if you run the stuff in a different machine, you have to create the alias first.

      And once you lose the machine and are trying to restore your backups, you can’t run alias and discover what doThingy actually does.

  • AnanasMarko@lemmy.world
    link
    fedilink
    arrow-up
    7
    ·
    11 天前

    Since I’m somewhat of a simpleton… isn’t that how pipelines actually work? The only difference being, they’re all (scripts) available from a centralized system and triggered i.e. with webhooks?

    Instead of a local script on a server, the system opens i.e. a ssh session and runs the script step by step remotely?

    So is that the joke or am I missing something?

    • orhtej2@eviltoast.org
      link
      fedilink
      English
      arrow-up
      12
      ·
      11 天前

      Pipelines are meant to be versioned an replicable, as opposed to a hack job that only runs on a forgotten server in someone’s closet depicted in the meme.

  • gmtom@lemmy.world
    link
    fedilink
    arrow-up
    6
    ·
    10 天前

    Oh man, you guys should see what I was cooking up at my old place.

    Head office too shitty to give us an actual asset management solution, but we did have full access to the Microsoft suite, so i used a SharePoint lists as databases, powerapps apps running on iPads for all the data entry ux and then like two dozen hacked together power automate flows linking them all together as well as taking any Info out of the actual IT systems head office used and since we didn’t have API access to those system any data feeding back in to them would be in the form of automated emails that the poor 1st line techs in head office would have to sort through and process manually.

    • Trainguyrom@reddthat.com
      link
      fedilink
      English
      arrow-up
      1
      arrow-down
      1
      ·
      11 天前

      As much as I love the magic of working and attending meetings in your undies, I’ve found I’m a far better professional if I’m actually fully dressed while I work. And when I go into the office I always wear something with a collar even at workplaces where that’s overdressed. It just puts me in the right mindset to be the best I can be at what I do

      • phutatorius@lemmy.zip
        link
        fedilink
        arrow-up
        4
        ·
        11 天前

        I’m always fully dressed while working remotely. That is, if wearing a bow on my winkie counts as “dressed.”