How I Structure New Projects In Golang

Поделиться
HTML-код
  • Опубликовано: 29 янв 2025

Комментарии • 118

  • @anthonygg_
    @anthonygg_  Год назад +1

    ► Join my Discord community for free education 👉 discord.com/invite/Ac7CWREe58
    ► Exclusive Lessons, Mentorship, And Videos 👉 www.patreon.com/anthonygg_
    ► 50% OFF on my Golang course 👉 fulltimegodev.com
    Thanks for watching

  • @omgItsGreg
    @omgItsGreg Год назад +83

    God I wish I had your mindset... you just stick to whatever works best for you.. I always look around and doubt my choices, thinking there is a better way of doing it, and then getting stuck on simple things.

    • @anthonygg_
      @anthonygg_  Год назад +21

      I always keep things simple, but, always eager to steal other patterns and utilize them when they make sense.

    • @jhjacobs81
      @jhjacobs81 Год назад +3

      You’re not alone :( and always there’s the next best framework to try, exhausting 😂

    • @quandaledingle9127
      @quandaledingle9127 Год назад +2

      Your biggest critic is going to be yourself

  • @vcothur7
    @vcothur7 Год назад +11

    I have been searching for a good structure for my go backend that I have for my website, and you decided to post this. Thank you!

  • @Steliosgiannatos
    @Steliosgiannatos 4 месяца назад

    Very refreshing to see an actual working project how it works on a structure level. I also like your approach, there is no perfect solution just compromises on different things!

  •  Год назад +23

    Please, record a video about unit tests in golang, the best practices, how to mock things, how to achieve 100% coverage when we have things like database or external calls.
    Which kind of tests (unit, integration, e2e, etc.) real projects used to write in golang's universe?
    It's a content that is hard to find in a unique video. Thanks for your great job.

    • @manfrombritain6816
      @manfrombritain6816 Год назад +1

      this is the real shit. people focusing on coding tutorials... coding is the simple part. proper structure, testing, integration, devops... this is harder to learn imo. especially before doing it on the job

    • @RogueAfterlife
      @RogueAfterlife Год назад

      Consider the case of testing log writes to standard output vs writes to a file. Unit testing ensures the output from the logger is what I expect whereas integration tests ensure the log line was written. These illustrate fundamentally different testing scenarios.
      I don't think mocks are useful in unit testing. Tests written in Go are for Go code. Although it might be tempting to use Go's testing framework for integration tests; writing tests concerning external systems is non-trivial because, the scope of the test expands combinatorially to what ever the dependency outputs. If I'm writing tests for my SQL schema, for example, I would write a separate program to test just that and maybe that program would be written in Go!

    • @vickylance
      @vickylance 9 месяцев назад

      @@manfrombritain6816 We use pact testing along with unit testing which is way much better than writing integration tests

    • @themaridv2000
      @themaridv2000 8 месяцев назад +1

      Yeees, please!

  • @rezaklink401
    @rezaklink401 Месяц назад

    Your channel is amazing, the people who get to work with you are seriously lucky my brother 💪

  •  Год назад +5

    Thank you for great video. I really like your approach with simplicity. I'm just learning Go for my hobby projects. And you are helping me so much. (Btw at work we are using C#)

  • @iliassglitch
    @iliassglitch Год назад +2

    Thank you so much for these videos Anthony.

  • @Insomn3s
    @Insomn3s Год назад +1

    Your videos are priceless as an example of "practical developer approach"

  • @ekeminios
    @ekeminios Год назад

    Thanks for sharing Anthony!
    Well explained and detailed.

  • @Programming-lr1nb
    @Programming-lr1nb Год назад +1

    "Is it a way to go? Pfft. I have no fucking clue" is my new life credo

  • @ta5alof297
    @ta5alof297 Год назад +2

    You don't need a separate schema between migration and SQLC. I'm using goose for migrations and SQLC supports it out of the box.. 1 directory for migrations which contains the schema changes.

  • @Jackbeti
    @Jackbeti Год назад +11

    Hey Anthony. Why do you think most organizational projects prefer clean architecture over hexagonal architecture? If possible, could you provide an example project implementing hexagonal architecture?

  • @tirumalraot
    @tirumalraot Год назад

    4:36 "Which in your case, in most of the cases it never be!" That actually hurts

    • @JohnSchuhr
      @JohnSchuhr Год назад

      Yeah, I felt it too - 😂

  • @viveksingh9223
    @viveksingh9223 11 месяцев назад +2

    Can you tell me what theme you are using?

  • @francesctravesa
    @francesctravesa Год назад +3

    So all the types are public? not a little bit of encapsulation with some information hiding? like smart creators to make sure the structs are always in a valid state? Some rich domain then at least? and when you want use some inverse dependency injection and clean architecture? I think there must be a smart way to implement all of these best practices with go?

    • @anthonygg_
      @anthonygg_  Год назад +7

      Stop thinking. Start pressing buttons. You are behind.

  • @charlesbcraig
    @charlesbcraig Год назад +6

    AGG: if you have a performance issue, congratulations you’ve made it
    Me: 😁
    AGG: But most of you won’t
    Me: 😭

  • @karolkotula9279
    @karolkotula9279 Год назад +3

    Hi Anthony. Really great stuff here! It's of excellent quality.
    Can you please start swearing in your native language? :D
    I guess it would be even more fun to watch your vids :)
    THANK YOU !!!

    • @anthonygg_
      @anthonygg_  Год назад

      Ok I will try that

    • @TrzyTukany
      @TrzyTukany Год назад

      Only using your native, you can be truly "authentic" :)
      Like delicate seasoning in your food (for thought) :D

  • @kazimir9576
    @kazimir9576 Год назад

    yeah in 04:00 u are right, ppl very often tend to overcode, over complicate everything just because they think its how it must be done, "book way". and spend 1 week on doing smth that for business does not matter. They need to understand its a business, and if you spend a lot of time just because you want smth make 5ms faster, try to tell the business how much money it cost for them to gain 5ms faster api call for some profile update etc. ;)

  • @ekallivrousis
    @ekallivrousis Год назад +1

    Hey Anthony, thank you for this video, the way you describe things is just so real if that makes sense. Im new to the Go world and project structure is always a huge mind blocker for me. Do you happen to have a public repo of the above structure? I wanted to go through it more, i really like how clean it is the only thing i dont think i follow is the global db instance.
    Now i know you said this in video and its just all in how it works for you and your team. I personally only use go for personal projects and i rely on the test files to make sure i dont break as much as i can. That includes the database. I setup tests to confirm that basically im getting data back from the database. Is this still possible with a global database?

    • @anthonygg_
      @anthonygg_  Год назад

      Better not to is a better practice

  • @shravan2891
    @shravan2891 11 месяцев назад +1

    why didn't you use this structure in you fulltimegodev course

    • @anthonygg_
      @anthonygg_  11 месяцев назад

      Because we are free.

  • @Dsouza10082
    @Dsouza10082 Год назад

    Amazing as always.

  • @caiomartins8255
    @caiomartins8255 5 месяцев назад

    Excellent video, thanks. Btw What is his vs code theme ?

  • @Simple_OG
    @Simple_OG 8 месяцев назад +1

    Anthonyy what theme are you using it lokks so cool

  • @Ярослав-о5б6т
    @Ярослав-о5б6т Год назад +1

    Great video! Antony tell me the name of the vscode theme please

  • @sheraztariq8973
    @sheraztariq8973 8 месяцев назад

    use ent for database and kudos for good explanation, i was having hard time for structuring my project

  • @garbagechannel6514
    @garbagechannel6514 Год назад +5

    I noticed everything is very flat. Im used to having subfolders in my project coming from C#. It's a bit harder to do in Go because namespaces are not a thing.
    So should it be flat and end up with a ton of files in a module, as well as many modules or would you say its ok to have nested folders?

    • @anthonygg_
      @anthonygg_  Год назад +9

      The problem in Go with a lot of nested folders is circular dependencies.

    • @garbagechannel6514
      @garbagechannel6514 Год назад +4

      @@anthonygg_ yes, i already ran into that :P i suppose i just have to get used to a flatter structure with Go

    • @anthonygg_
      @anthonygg_  Год назад +3

      @@garbagechannel6514I also learned that the hard way 😂😢

  • @comedyclub333
    @comedyclub333 Год назад

    Also, on the performance argument: As you said, performance doesn't matter (most of the time). If performance is your bottleneck (as in really being an issue) you probably did something horribly wrong when deploying your app. No framework swap is going to change that. I mean, many people (and also big companies) use python, one of the slowest languages known. Because you save a lot of money when developing the app and if performance is an issue you just throw the money you saved onto your deployment infrastructure to make it work.

  • @ZenonCreations
    @ZenonCreations 8 месяцев назад

    dont you use DTOs in go lang backend development?

  • @eyob7232
    @eyob7232 Год назад +4

    I highly disagree with global variables, I believe creating a singleton and passing it as a parameter is a better choice. I agree with you having a dedicated folder for queries, and data related stuff, but I would call that folder repository or sth like that, data is a bit too general, just my 2 cents.

    • @anthonygg_
      @anthonygg_  Год назад +4

      Data is indeed general. But repository sounds so cringe. The global db, yeah, sometimes we need to close our eyes.

  • @manpt123
    @manpt123 Год назад +1

    I still often ask myself if I am writing golang in standard way😂 thank you for the video 🎉

  • @lancemarchetti8673
    @lancemarchetti8673 Год назад

    I have an idea for a new method of digital Steganography whereby a lager image can be hidden in a smaller one without changing the filesize or quality of the host image. Will Golang work better to build this app in Windows, or should I battle it out with JS and html? . I'm totally new to programming so it feels like I've just thrown myself into the deep end.... lol

  • @virility
    @virility Год назад +1

    hey anthony, what laptop do you use?

    • @anthonygg_
      @anthonygg_  Год назад

      I use a desktop. Custom build

    • @virility
      @virility Год назад +1

      @@anthonygg_ what about when you r traveling? Do u carry ur desktop around you when you travel?

    • @anthonygg_
      @anthonygg_  Год назад

      I have a macbook (old one)

  • @ibraim3197
    @ibraim3197 Год назад +8

    You are wrong about performance. It doesn't always come with a large user base, it's also can be a consequence of inefficient DB-layer (N+1 query etc) or algorithms

    • @joef7884
      @joef7884 Год назад +1

      You're right, but in the specific context of "which framework should I use" which is what he was talking about, generally each framework isn't going to make one of those mistakes; it will still be up to you the developer to use them wisely with good algorithms and queries.

    • @fernandoacorreia
      @fernandoacorreia 8 месяцев назад

      He was talking about the relative performance of different web frameworks. He is correct.

  • @varyous_ch
    @varyous_ch Год назад +1

    Could you show an example of a microservices structure with Docker/k8s? Just curios how would you do it :)

  • @ScienceForToday-lm7nb
    @ScienceForToday-lm7nb 11 месяцев назад

    Thank you for this video.

  • @frankfix247
    @frankfix247 9 месяцев назад +1

    Drop the plenum naming in packages and the infamous util package. This is according to the Golang docs.

    • @anthonygg_
      @anthonygg_  9 месяцев назад

      Ok franky

    • @frankfix247
      @frankfix247 9 месяцев назад

      @@anthonygg_ It wasn't meant to be sarcastic. Keep up the good work!

  • @hanes2
    @hanes2 19 дней назад

    You're using supabase? that's cool.

  • @d_andreev
    @d_andreev Год назад +2

    Nice initial project structure! Btw, how are you testing business logic inside the pkg folder? Are you using some kind of dependency injection?

  • @WaldirBorbaJunior
    @WaldirBorbaJunior Год назад

    Wow... blazing amaze, could you please share your start project ?

  • @jalbers3150
    @jalbers3150 Год назад

    Would love to see how/where you deploy all this.
    Do you do managed db’s and stuff like that for production?

  • @dejanduh2645
    @dejanduh2645 Год назад

    Is there a link to this project or this project structure? Looks very clean

  • @AbdulRehman-pb5od
    @AbdulRehman-pb5od Год назад +2

    I use fiber only bcz they have best documentation I have ever came through.

  • @salihbozkaya9357
    @salihbozkaya9357 Год назад

    Dad, where did you been all those times.missed you

  • @kurtlee138
    @kurtlee138 11 месяцев назад +1

    didnt know the rock makes programming videos

    • @anthonygg_
      @anthonygg_  11 месяцев назад

      Years of wrestling and testosteron abuse made me look for something more subtle.

  • @ralphlorenzo9473
    @ralphlorenzo9473 Год назад

    What do you think of the new routing as of version 1.22?

  • @Mari_Selalu_Berbuat_Kebaikan
    @Mari_Selalu_Berbuat_Kebaikan 11 месяцев назад

    Let's always do alot of good ❤️

  • @woodmanmade
    @woodmanmade Год назад

    "Models belong on the catwalk" 🤣

  • @D3FKONMusik123
    @D3FKONMusik123 Год назад +1

    Hey Anthony. Your videos have a lot of value, but they are usually structured so poorly and runs for so long that it's hard to follow for more than a couple of mins. But really appreciate all the value

    • @anthonygg_
      @anthonygg_  Год назад +1

      Correct this channel is not for the weak. Sorry my man.

    • @D3FKONMusik123
      @D3FKONMusik123 Год назад

      @@anthonygg_ That makes a lot of sense. Congrats!

  • @mrlectus
    @mrlectus Год назад +1

    My OCD says I need everything to be organized and properly structured

  • @rw_panic0_0
    @rw_panic0_0 Год назад +1

    what means "handlers" if your program works with not only http, but with websockets and kafka? Are these kafka handlers, http or websocket handlers? What if your types are not just structs but full domain models with methods interfaces etc? What if I have a lot of types, finding a type will become a problem. For a man who just got into the codebase there are no clear difference between "data" and "types". Util folder have to probably be split up into encryptuitl etc. I don't think this is a scalable project structure. However I agree that going with DDD or hex arch is a bad idea, your structure works PERFECTLY good for small projects. But I personally find splitting program into packages (multiple "feature-sliced" packages which have their own types, data, and util) and being explicit about your naming (types, util, handlers are pretty vague) is most important thing, because being vague and putting similar functionality in different places is the thing that makes project structure unscalable.

    • @anthonygg_
      @anthonygg_  Год назад

      Like I mentioned in the video, this is how it is right now, but probably subject to change in the future. Happy to share that later

  • @zzej
    @zzej Год назад

    wait.... how can golang render svelte? that would be awesome. or is it svelte as an SPA?

    • @nivethan_me
      @nivethan_me Год назад

      front-end with Svelte and backend with Golang i guess.

  • @dejanduh2645
    @dejanduh2645 Год назад

    Is there a link to the source code?

  • @深夜酒吧
    @深夜酒吧 Год назад +4

    leave a mark here, so remind me watch it later on

    • @anthonygg_
      @anthonygg_  Год назад +3

      Reminding you to watch

    • @iamsupriyo
      @iamsupriyo Год назад +2

      Bro came back

    • @pattyspanker8955
      @pattyspanker8955 Год назад +2

      Remind me to remind user he has a reminder to watch this video

  • @Benony91
    @Benony91 Год назад

    17:46 `AumMax50Million = “10-15mil”` is this a bug?

  • @sjzz
    @sjzz 9 месяцев назад

    I just follow my JS folder pattern controllers, service, routes, middleware etc

  • @collapser_team
    @collapser_team Год назад +1

    Can you share this project, please?

    • @anthonygg_
      @anthonygg_  Год назад

      I cant or I go to jail

    • @collapser_team
      @collapser_team Год назад

      just a template without NDA stuff (and you have already showed the content oops)@@anthonygg_

  • @fluctura
    @fluctura Год назад

    Data is where your data belongs to. For example seed data.
    Model is where you save what model/shape your data has.
    So yeah.. that I think was the original idea behing that common sense project layout
    Nowadays your data is stored on S3 or whatever..
    but if we are splitting hairs, why not putting your db and migrations into data folder as well? 😅 its data too 😮😂

  • @arielsashcov99
    @arielsashcov99 Год назад

    Exactly what I was searching for

  • @XxMissingDataxX
    @XxMissingDataxX Год назад

    Very nice

  • @MrMu2sS
    @MrMu2sS 11 месяцев назад

    French devs will cry in ddd

  • @yarbersheer8559
    @yarbersheer8559 10 месяцев назад +1

    Man, just use goose for migrations)

  • @Buiscit1738
    @Buiscit1738 Год назад +1

    dopamine!

  • @bandr-dev
    @bandr-dev Год назад

    "a drop pkg in cmd that drops all the tables with a sql command" HUHHHHHH????
    How is any of those folders in the cmd folder good organization

  • @dencasio6141
    @dencasio6141 Год назад

    util?

  • @ibrahimkoz1983
    @ibrahimkoz1983 10 месяцев назад +2

    This structuring is away from the best practices and the philosophy of packages. You should not organize your based on technical details. Packages should be organised based on layers, not for grouping.

    • @anthonygg_
      @anthonygg_  10 месяцев назад

      True. But how many revenue does your company make?

    • @ibrahimkoz1983
      @ibrahimkoz1983 10 месяцев назад +1

      @@anthonygg_ disappointed. I was following you for a long time, learnt a lot from you. You replied with a fallacy :/

    • @anthonygg_
      @anthonygg_  10 месяцев назад

      I just said you are right.

  • @krq999
    @krq999 Год назад

    Can you post something related to sql databases? Generators, creating records, relations etc

  • @luciancristianpop2735
    @luciancristianpop2735 Год назад +1

    In the first minute you're asking for the thumbs up and subscription, no matter the content, this is rude.

  • @whtkeys8190
    @whtkeys8190 Год назад +1

    Really bad bro

  • @MCDyma
    @MCDyma Год назад +1

    And again you are in GoWeekly #​480 - OCTOBER 17, 2023
    Congratulations

  • @DoktorKumpel
    @DoktorKumpel 11 месяцев назад

    I thought with go build you have to specify each package. how come you only specify cmd/api/main.go?

    • @RubberGopher
      @RubberGopher 5 месяцев назад

      My comment makes the assumption that module mode is enabled.
      So "go run" will look for "go.mod" in the current directory or any parent directory and uses that to discover the module and its name. It can then discover the location of all the imports for the module with the help of the module information. As you import a module and/or any of the module's packages, it will discover all the files in those packages and you can simply import and use whatever is exported in the package.
      In this case, where he just points to ./cmd/api/main.go, will cause it to not find other files in ./cmd/api so adding additional files that main.go relies on will cause an error. The better approach is to just point to the main package and not the file, i.e "go run ./cmd/api" and it will discover all the files in it and it will build regardless whether there is only one or many files, as long as it's able to find "main.main()".
      The filename "main.go" has no meaning other than being helpful to humans for get a hint of what it contains. Having a main.go in other packages (not main) is not helpful unless there is something called main in there too. Giving your files good names is as important to you as naming variables and packages. If you don't know what to name a file, just seek inspiration from the name of the package or the name of whatever type or function you have in the file.
      If you have main.go in the root of your module, you can just do "go run ." and it will be happy.