this post was submitted on 15 Nov 2023
777 points (96.2% liked)

Programmer Humor

19463 readers
152 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 1 year ago
MODERATORS
 
top 50 comments
sorted by: hot top controversial new old
[–] wolo@lemmy.blahaj.zone 142 points 11 months ago* (last edited 11 months ago) (10 children)

my website's backend is made with bash, it calls make for every request and it probably has hundreds of remote arbitrary code execution bugs that will get me pwned someday, it's great

edit: to clarify, it uses a rust program i made to expose the bash scripts as http endpoints, i'm not crazy enough to implement http in bash

it behaves like a static file server, but if a file has the others-execute permission bit set it executes the file instead of reading it

it's surprisingly nice for prototyping since you can just write a cli program and it's automatically available over http too

[–] camr_on@lemmy.world 80 points 11 months ago

For my own sanity, I choose to believe you're lying

[–] PupBiru@kbin.social 74 points 11 months ago (2 children)
[–] agent_flounder@lemmy.world 52 points 11 months ago

These wounds appear to be self-inflicted.

[–] wolo@lemmy.blahaj.zone 16 points 11 months ago (1 children)

i thought it was neat how php lets you write your website's logic with the same directory tree pattern that clients consume it from, but i didn't want to learn php so i made my own, worse version

[–] technojamin@lemmy.world 8 points 11 months ago

That’s a pretty reasonable reaction to the proposition of learning PHP.

[–] Fashim@lemmy.world 59 points 11 months ago (2 children)

I pity the hacker who ends up in your system

[–] agilob@programming.dev 51 points 11 months ago

You live like this?

[–] wolo@lemmy.blahaj.zone 9 points 11 months ago (1 children)

I've taken some precautions, it's running in a container as an unprivileged user and the only writable mount is the directory where make writes rendered pages, but i probably should move it into a vm if i want to be completely safe lol

[–] sdw@lemmy.ca 9 points 11 months ago (1 children)
[–] wolo@lemmy.blahaj.zone 9 points 11 months ago* (last edited 11 months ago)

Maybe I'll finally move it into a VM so I can send a link to it here without tempting people :P

[–] bdonvr@thelemmy.club 50 points 11 months ago (1 children)

I designed a chip architecture that runs bash code on silicon.

I reimplemented x86 assembly in purely bash script.

[–] SpaceNoodle@lemmy.world 36 points 11 months ago
[–] tetris11@lemmy.ml 26 points 11 months ago

Set -e, please for the love of god, set -e

load more comments (5 replies)
[–] agilob@programming.dev 120 points 11 months ago (7 children)

Before nginx was a thing, I worked with a guy who forked apache httpd and wrote this blog in C, like, literally embedded html and css inside the server, so when he made a tpyo or was adding another post he had to recompile the source code. The performance was out of this world.

[–] Schmeckinger@feddit.de 31 points 11 months ago* (last edited 11 months ago) (1 children)

There are a lot of solutions like that in rust. You basically compile the template into your code.

[–] vox@sopuli.xyz 8 points 11 months ago* (last edited 11 months ago) (2 children)

yeah, templates can be parsed at compile time but these frameworks are not embeeding whole fucking prerendered static pages/assets

[–] sebsch@discuss.tchncs.de 8 points 11 months ago

They are nowadays. Compiling assets and static data into rust and deliver virtual DOM via websocket to the browser is the new cool kid in the corner.

Have a look at dioxus

load more comments (1 replies)
[–] PieMePlenty@lemmy.world 15 points 11 months ago (2 children)

Does a file lookup really take that long? Id say the trick was to have just plain old html with no bloat and you're golden.

[–] agilob@programming.dev 29 points 11 months ago (1 children)

Blog content was stored in memory and it was served with zero-copy to the socket, so yea, it's way faster. It was before times of php-fpm and opcache that we're using now. Back then things were deployed and communicated using tcp sockets (tcp to rails, django or php) or reading from a disk, when the best HDDs were 5600rpm, but rare to find on shared hosting.

[–] THE_STORM_BLADE@lemmy.world 6 points 11 months ago (1 children)

Couldn't the html be loaded into memory at the beginning of the program and then served whenever? I understand the reading from disk will be slow, but that only happens once in the beginning.

load more comments (1 replies)
[–] MeanEYE@lemmy.world 8 points 11 months ago

The answer is no. The more file is used the longer it sits in kernel filesystem cache. Getting file from cache versus having it in process memory is few function calls away all of which takes few microseconds. Which is negligible in comparison to network latency and other small issues that might be present in the code.

On few of our services we decided to store client configuration in JSON files on purpose instead of running with some sort of database storage. Accessing config is insanely fast and kernel makes sure that file is cached so when reading the file you always get fast and latest version. That service is currently handling around 100k requests a day, but we've had peaks in past that went up to almost a million requests a day.

Besides when it comes to human interaction and web sites you only need to get first contentful paint within one second. Anything above 1.5s will feel sluggish, but below 1s, it feels instant. That gives you on average around 800ms to send data back. Plenty of time unless you have a dependency nightmare and parse everything all the time.

[–] bazsalanszky@lemmy.toldi.eu 13 points 11 months ago

This reminds me of one of my older projects. I wanted to learn more about network communications, so I started working on a simple P2P chat app. It wasn't anything fancy, but I really enjoyed working on it. One challenge I faced was that, at the time, I didn't know how to listen for user input while handling network communication simultaneously. So, after I had managed to get multiple TCP sockets working on one thread, I thought, why not open another socket for HTTP communication? That way, I could incorporate a fancy web UI instead of just a CLI interface.

So, I wrote a simple HTTP server, which, in hindsight, might not have been necessary.

[–] justJanne@startrek.website 11 points 11 months ago (3 children)
load more comments (3 replies)
load more comments (3 replies)
[–] fireflash38@lemmy.world 73 points 11 months ago (2 children)

What if, get this, we put the bash scripts in yaml. And then put it in kubernetes.

[–] PupBiru@kbin.social 57 points 11 months ago (1 children)

well now you’re just describing ansible

[–] Vash63@lemmy.world 10 points 11 months ago

Very, very bad Ansible.

[–] nxdefiant@startrek.website 27 points 11 months ago (1 children)

Have you considered embedding python in those bash scripts? I have done this, and it is glorious.

[–] tetris11@lemmy.ml 36 points 11 months ago (1 children)

I wrote my webserver in pure bash.

bash -c "python -m http.server 8080"

[–] MeanEYE@lemmy.world 7 points 11 months ago (1 children)

Did you know you can zip entire Python project into single file and make it executable? Quite a neat feature. Shove all dependencies, modules and assets in there and voila. Single file python application.

load more comments (1 replies)
[–] Socsa@sh.itjust.works 62 points 11 months ago (2 children)

This is false, you also need vim and tmux

[–] Rin@lemm.ee 37 points 11 months ago (1 children)

Idk about you but I use echo and sed to edit my files.

[–] clearleaf@lemmy.world 67 points 11 months ago

Let's just get this out of the way

[–] Telodzrum@lemmy.world 16 points 11 months ago (3 children)

Microsoft Word is the only text editor I need.

load more comments (3 replies)
[–] FauxPseudo@lemmy.world 32 points 11 months ago (4 children)

I'm currently trying to relearn all my advanced bash in python.

[–] aes@lemm.ee 11 points 11 months ago* (last edited 11 months ago) (1 children)

i already learned how to use my operating system, now you're telling me I have to learn 30 new libraries that do the exact same shit?

[–] bort@feddit.de 11 points 11 months ago* (last edited 11 months ago)

no, you'll also have to learns each libraries special quirks on your OS

load more comments (3 replies)
[–] MonkderZweite@feddit.ch 21 points 11 months ago* (last edited 11 months ago) (1 children)

Just don't call it with #!/bin/sh. Because that's POSIX shell, not bash.

[–] philm@programming.dev 5 points 11 months ago* (last edited 11 months ago) (6 children)

but effectively it's bash, I think /bin/sh is a symlink to bash on every system I know of...

Edit: I feel corrected, thanks for the information, all the systems I used, had a symlink to bash. Also it was not intended to recommend using bash functionality when having a shebang !#/bin/sh. As someone other pointed out, recommendation would be #!/usr/bin/env bash, or !#/bin/sh if you know that you're not using bash specific functionality.

[–] MonkderZweite@feddit.ch 21 points 11 months ago* (last edited 11 months ago) (4 children)

Still don't do this. If you use bash specific syntax with this head, that's a bashism and causes issues with people using zsh for example. Or with Debian/*buntu, who use dash as init shell.

Just use #!/bin/bash or #!/usr/bin/env bash if you're funny.

[–] wolo@lemmy.blahaj.zone 8 points 11 months ago (6 children)

#!/bin/bash doesn't work on NixOS since bash is in the nix store somewhere, #!/usr/bin/env bash resolves the correct location regardless of where bash is

load more comments (6 replies)
load more comments (3 replies)
[–] JackbyDev@programming.dev 15 points 11 months ago

No no no no no, do not believe this you will shoot yourself in the foot.

https://wiki.debian.org/Shell

Beginning with DebianSqueeze, Debian uses Dash as the target of the /bin/sh symlink. Dash lacks many of the features one would expect in an interactive shell, making it faster and more memory efficient than Bash.

From DebianSqueeze to DebianBullseye, it was possible to select bash as the target of the /bin/sh symlink (by running dpkg-reconfigure dash). As of DebianBookworm, this is no longer supported.

[–] SurpriseWaterfall@sopuli.xyz 5 points 11 months ago

It is a symlink, but bash will automatically enable posix compliance mode if you use it. So any bash specific features will bomb out unless you explicitly reset it in the script.

load more comments (3 replies)
[–] MeanEYE@lemmy.world 19 points 11 months ago (1 children)

I feel like this with Python these days.

load more comments (1 replies)
[–] Maoo@hexbear.net 13 points 11 months ago (3 children)

You're not at scale unless you're deploying OpenStack to run a WordPress site.

load more comments (3 replies)
[–] cyborganism@lemmy.ca 10 points 11 months ago

All you need are Bash scripts with chroot and cgroups and some ssh access.

[–] SpaceNoodle@lemmy.world 9 points 11 months ago

Never sed when you can bash.

load more comments
view more: next ›