diff --git a/website/blog/2023-11-14-specify-prod-environment.md b/website/blog/2023-11-14-specify-prod-environment.md new file mode 100644 index 00000000000..c6ad2b31027 --- /dev/null +++ b/website/blog/2023-11-14-specify-prod-environment.md @@ -0,0 +1,73 @@ +--- + +title: Why you should specify a production environment in dbt Cloud +description: "The bottom line: You should split your Environments in dbt Cloud based on their purposes (e.g. Production and Staging/CI) and mark one environment as Production. This will improve your CI experience and enable you to use dbt Explorer." +slug: specify-prod-environment + +authors: [joel_labes] + +tags: [dbt Cloud] +hide_table_of_contents: false + +date: 2023-11-14 +is_featured: false + +--- + +:::tip The Bottom Line: +You should [split your Jobs](#how) across Environments in dbt Cloud based on their purposes (e.g. Production and Staging/CI) and set one environment as Production. This will improve your CI experience and enable you to use dbt Explorer. +::: + +[Environmental segmentation](/docs/environments-in-dbt) has always been an important part of the analytics engineering workflow: + +- When developing new models you can [process a smaller subset of your data](/reference/dbt-jinja-functions/target#use-targetname-to-limit-data-in-dev) by using `target.name` or an environment variable. +- By building your production-grade models into [a different schema and database](https://docs.getdbt.com/docs/build/custom-schemas#managing-environments), you can experiment in peace without being worried that your changes will accidentally impact downstream users. +- Using dedicated credentials for production runs, instead of an analytics engineer's individual dev credentials, ensures that things don't break when that long-tenured employee finally hangs up their IDE. + +Historically, dbt Cloud required a separate environment for _Development_, but was otherwise unopinionated in how you configured your account. This mostly just worked – as long as you didn't have anything more complex than a CI job mixed in with a couple of production jobs – because important constructs like deferral in CI and documentation were only ever tied to a single job. + +But as companies' dbt deployments have grown more complex, it doesn't make sense to assume that a single job is enough anymore. We need to exchange a job-oriented strategy for a more mature and scalable environment-centric view of the world. To support this, a recent change in dbt Cloud enables project administrators to [mark one of their environments as the Production environment](/docs/deploy/deploy-environments#set-as-production-environment-beta), just as has long been possible for the Development environment. + +Explicitly separating your Production workloads lets dbt Cloud be smarter with the metadata it creates, and is particularly important for two new features: dbt Explorer and the revised CI workflows. + + + +## Make sure dbt Explorer always has the freshest information available + +**The old way**: Your dbt docs site was based on a single job's run. + +**The new way**: dbt Explorer uses metadata from across every invocation in a defined Production environment to build the richest and most up-to-date understanding of your project. + +Because dbt docs could only be updated by a single predetermined job, users who needed their documentation to immediately reflect changes deployed throughout the day (regardless of which job executed them) would find themselves forced to run a dedicated job which did nothing other than run `dbt docs generate` on a regular schedule. + +The Discovery API that powers dbt Explorer ingests all metadata generated by any dbt invocation, which means that it can always be up to date with the applied state of your project. However it doesn't make sense for dbt Explorer to show docs based on a PR that hasn't been merged yet. + +To avoid this conflation, you need to mark an environment as the Production environment. All runs completed in _that_ environment will contribute to dbt Explorer's, while others will be excluded. (Future versions of Explorer will support environment selection, so that you can preview your documentation changes as well.) + +## Run Slimmer CI than ever with environment-level deferral + +**The old way**: [Slim CI](/guides/set-up-ci?step=2) deferred to a single job, and would only detect changes as of that job's last build time. + +**The new way**: Changes are detected regardless of the job they were deployed in, removing false positives and overbuilding of models in CI. + +Just like dbt docs, relying on a single job to define your state for comparison purposes leads to a choice between unnecessarily rebuilding models which were deployed by another job, or creating a dedicated job that runs `dbt compile` on repeat to keep on top of all changes. + +By using the environment as the arbiter of state, any time a change is made to your Production deployment it will immediately be taken into consideration by subsequent Slim CI runs. + +## The easiest way to break apart your jobs {#how} + + + +For most projects, changing from a job-centric to environment-centric approach to metadata is straightforward and immediately pays dividends as described above. Assuming that your Staging/CI and Production jobs are currently intermingled, you can extricate them as follows: + +1. Create a new dbt Cloud environment called Staging +2. For each job that belongs to the Staging environment, edit the job and update its environment +3. Tick the ["Mark as Production environment" box](/docs/deploy/deploy-environments#set-as-production-environment-beta) in your original environment's settings + +## Conclusion + +Until very recently, I only thought of Environments in dbt Cloud as a way to use different authentication credentials in different contexts. And until very recently, I was mostly right. + +Not anymore. The metadata dbt creates is critical for effective data teams – whether you're concerned about cost savings, discoverability, increased development speed or reliable results across your organization – but is only fully effective if it's segmented by the environment that created it. + +Take a few minutes to clean up your environments - it'll make all the difference. diff --git a/website/blog/categories.yml b/website/blog/categories.yml index 8103f58cc33..45acf246dff 100644 --- a/website/blog/categories.yml +++ b/website/blog/categories.yml @@ -19,3 +19,5 @@ display_title: SQL magic description: Stories of dbt developers making SQL sing across warehouses. is_featured: true +- name: dbt Cloud + description: Using dbt Cloud to build for scale \ No newline at end of file diff --git a/website/docs/community/spotlight/alison-stanton.md b/website/docs/community/spotlight/alison-stanton.md new file mode 100644 index 00000000000..ffa5e8499c7 --- /dev/null +++ b/website/docs/community/spotlight/alison-stanton.md @@ -0,0 +1,84 @@ +--- +id: alison-stanton +title: Alison Stanton +description: | + I started programming 20+ years ago. I moved from web applications into transforming data and business intelligence reporting because it's both hard and useful. The majority of my career has been engineering for SaaS companies. For my last few positions I've been brought in to transition larger, older companies to a modern data platform and ways of thinking. + + I am dbt Certified. I attend Coalesce and other dbt events virtually. I speak up in dbt Slack and on the dbt-core, dbt-redshift, and dbt-sqlserver repositories. dbt Slack is my happy place, especially #advice-for-dbt-power-users. I care a lot about the dbt documentation and dbt doc. +image: /img/community/spotlight/alison.jpg +pronouns: she/her +location: Chicago, IL, USA +jobTitle: AVP, Analytics Engineering Lead +organization: Advocates for SOGIE Data Collection +socialLinks: + - name: LinkedIn + link: https://www.linkedin.com/in/alisonstanton/ + - name: Github + link: https://github.com/alison985/ +dateCreated: 2023-11-07 +hide_table_of_contents: true +--- + +## When did you join the dbt community and in what way has it impacted your career? + +I joined the dbt community when I joined an employer in mid-2020. To summarize the important things that dbt has given me: it allowed me to focus on the next set of data challenges instead of staying in toil. Data folks joke that we're plumbers, but we're digital plumbers and that distinction should enable us to be DRY. That means not only writing DRY code like dbt allows, but also having tooling automation to DRY up repetitive tasks like dbt provides. + +dbt's existence flipped the experience of data testing on it's head for me. I went from a)years of instigating tech discussions on how to systematize data quality checks and b) building my own SQL tests and design patterns, to having built-in mechanisms for data testing. + +dbt and the dbt community materials are assets I can use in order to provide validation for things I have, do, and will say about data. Having outside voices to point to when requesting investment in data up-front - to avoid problems later - is an under-appreciated tool for data leader's toolboxes. + +dbt's community has given me access to both a) high-quality, seasoned SMEs in my field to learn from and b) newer folks I can help. Both are gifts that I cherish. + +## What dbt community leader do you identify with? How are you looking to grow your leadership in the dbt community? + +I want to be when I grow up: + +MJ, who was the first person to ever say "data build tool" to me. If I'd listened to her then I could have been part of the dbt community years sooner. + +Christine Dixon who presented "Could You Defend Your Data in Court?" at Coalesce 2023. In your entire data career, that is the most important piece of education you'll get. + +The dbt community team in general. Hands-down the most important work they do is the dbt Slack community, which gives me and others the accessibility we need to participate. Gwen Windflower (Winnie) for her extraordinary ability to bridge technical nuance with business needs on-the-fly. Dave Connors for being the first voice for "a node is a node is a node". Joel Labes for creating the ability to emoji-react with :sparkles: to post to the #best-of-slack channel. And so on. The decision to foster a space for data instead of just for their product because that enhances their product. The extremely impressive ability to maintain a problem-solving-is-cool, participate-as-you-can, chorus-of-voices, international, not-only-cis-men, and we're-all-in-this-together community. + +Other (all?) dbt labs employees who engage with the community, instead of having a false separation with it - like most software companies. Welcoming feedback, listening to it, and actioning or filtering it out (ex. Mirna Wong, account reps). Thinking holistically about the eco-system not just one feature at a time (ex. Anders). Responsiveness and ability to translate diverse items into technical clarity and focused actions (ex. Doug Beatty, the dbt support team). I've been in software and open source and online communities for a long time - these are rare things we should not take for granted. + +Josh Devlin for prolificness that demonstrates expertise and dedication to helping. + +The maintainers of dbt packages like dbt-utils, dbt-expectations, dbt-date, etc. + +Everyone who gets over their fear to ask a question, propose an answer that may not work, or otherwise take a risk by sharing their voice. + +I hope I can support my employer and my professional development and my dbt community through the following: +-Elevate dbt understanding of and support for Enterprise-size company use cases through dialogue, requests, and examples. +-Emphasize rigor with defensive coding and comprehensive testing practices. +-Improve the onboarding and up-skilling of dbt engineers through feedback and edits on docs.getdbt.com. +-Contribute to the maintenance of a collaborative and helpful dbt community as the number of dbt practitioners reaches various growth stages and tipping points. +-Engage in dialogue. Providing feedback. Champion developer experience as a priority. Be a good open source citizen on Github. + +## What have you learned from community members? What do you hope others can learn from you? + +I have learned: + +Details on DAG sequencing. +How to make an engineering proposal a community conversation. +The dbt semantic layer +. +So many things that are now so engrained in me that I can't remember not knowing them. + +I can teach and share about: + +Naming new concepts and how to choose those names. +Reproducibility, reconciliation, and audits. +Data ethics. +Demographic questions for sexual orientation and/or gender identity on a form. I'm happy to be your shortcut to the most complicated data and most-engrained tech debt in history. +I also geek out talking about: reusing functionality in creative ways, balancing trade-offs in data schema modeling, dealing with all of an organization's data holistically, tracking instrumentation, and philosophy on prioritization. + +The next things on my agenda to learn about: + +Successes and failures in data literacy work. The best I've found so far is 1:1 interactions and that doesn't scale. +How to reduce the amount of time running dbt test takes while maintaining coverage. +Data ethics. +The things you think are most important by giving them a :sparkles: emoji reaction in Slack. + +## Anything else interesting you want to tell us? + +My gratitude to each community member for this community. diff --git a/website/docs/community/spotlight/bruno-de-lima.md b/website/docs/community/spotlight/bruno-de-lima.md index 7f40f66859c..0365ee6c6a8 100644 --- a/website/docs/community/spotlight/bruno-de-lima.md +++ b/website/docs/community/spotlight/bruno-de-lima.md @@ -2,11 +2,11 @@ id: bruno-de-lima title: Bruno de Lima description: | - I am an Analytics Engineer and aspiring tech writer coming from an academic engineering background. + Hi all! I'm a Data Engineer, deeply fascinated by the awesomeness dbt. I love talking about dbt, creating content from daily tips to blogposts and engaging with this vibrant community! - I worked at Indicium as an Analytics Engineer for more than a year, having worked with dbt (of course, every day) for transformation; BigQuery, Snowflake, and Databricks as data warehouses; Power BI and Tableau for BI; and Airflow for orchestration. + Started my career at the beginning of 2022 at Indicium as an Analytics Engineer, working with dbt from day 1. By 2023, my path took a global trajectory as I joined phData as a Data Engineer, expanding my experiences and forging connections beyond Brazil. While dbt is at the heart of my expertise, I've also delved into data warehouses such as Snowflake, Databricks, and BigQuery; visualization tools like Power BI and Tableau; and several minor modern data stack tools. - I actively participate in the dbt community, having attended two dbt meetups in Brazil organized by Indicium; writing about dbt-related topics in my Medium and LinkedIn profiles; contributing to the code; and frequently checking dbt Slack and Discourse, helping (and being helped by) other dbt practitioners. If you are a community member, you may have seen me around! + I actively participate in the dbt community, having attended two dbt Meetups in Brazil organized by Indicium; writing about dbt-related topics in my Medium and LinkedIn profiles; contributing to the code; and frequently checking dbt Slack and Discourse, helping (and being helped by) other dbt practitioners. If you are a community member, you may have seen me around! image: /img/community/spotlight/bruno-de-lima.jpg pronouns: he/him location: Florianópolis, Brazil @@ -18,7 +18,7 @@ socialLinks: link: https://www.linkedin.com/in/brunoszdl/ - name: Medium link: https://medium.com/@bruno.szdl -dateCreated: 2023-03-28 +dateCreated: 2023-11-05 hide_table_of_contents: true --- @@ -30,7 +30,7 @@ It took me some time to become an active member of the dbt community. I started Inspired by other members, especially Josh Devlin and Owen Prough, I began answering questions on Slack and Discourse. For questions I couldn't answer, I would try engaging in discussions about possible solutions or provide useful links. I also started posting dbt tips on LinkedIn to help practitioners learn about new features or to refresh their memories about existing ones. -By being more involved in the community, I felt more connected and supported. I received help from other members, and now, I could help others, too. I was happy with this arrangement, but more unexpected surprises came my way. My active participation in Slack, discourse, and LinkedIn opened doors to new connections and career opportunities. I had the pleasure of meeting a lot of incredible people and receiving exciting job offers. +By being more involved in the community, I felt more connected and supported. I received help from other members, and now, I could help others, too. I was happy with this arrangement, but more unexpected surprises came my way. My active participation in Slack, Discourse, and LinkedIn opened doors to new connections and career opportunities. I had the pleasure of meeting a lot of incredible people and receiving exciting job offers, including the one for working at phData. Thanks to the dbt community, I went from feeling uncertain about my career prospects to having a solid career and being surrounded by incredible people. diff --git a/website/docs/community/spotlight/dakota-kelley.md b/website/docs/community/spotlight/dakota-kelley.md new file mode 100644 index 00000000000..57834d9cdff --- /dev/null +++ b/website/docs/community/spotlight/dakota-kelley.md @@ -0,0 +1,30 @@ +--- +id: dakota-kelley +title: Dakota Kelley +description: | + For the last ~2 years I've worked at phData. Before that I spent 8 years working as a Software Developer in the public sector. Currently I'm a Solution Architect, helping our customers and clients implement dbt on Snowflake, working across multiple cloud providers. + + I first started reading about dbt when I was in grad school about 3 years ago. When I began with phData I had a fantastic opportunity to work with dbt. From there I feel in love with the Engineering practices and structure that I always felt were missing from Data Work. Since then, I've been fortunate enough to speak at Coalesce 2022 and at Coalesce 2023. On top of this, I've written numerous blogs about dbt as well. +image: /img/community/spotlight/dakota.jpg +pronouns: he/him +location: Edmond, USA +jobTitle: Solution Architect +companyName: phData +socialLinks: + - name: LinkedIn + link: https://www.linkedin.com/in/dakota-kelley/ +dateCreated: 2023-11-08 +hide_table_of_contents: true +--- + +## When did you join the dbt community and in what way has it impacted your career? + +I joined the dbt Community not too long after my first working experience. One of my passions is giving back and helping others, and being a part of the community allows me to help others with problems I've tackled before. Along the way it helps me learn new ways and see different methods to solve a wide variety of problems. Every time I interact with the community I've learned something new and that energizes me. + +## What dbt community leader do you identify with? How are you looking to grow your leadership in the dbt community? + +This is a tough one. I know there are several, but the main qualities I resonate with are from those who dig in and help each other. There are always nuances to others situations, and it's good to dig in together, understand those, and seek a solution. The other quality I look for is someone who is trying to pull others up with them. At the end of the day we should all be striving to make all things better than they were when we arrived, regardless if that's the dbt Community or the local park we visit for rest and relaxation. + +## What have you learned from community members? What do you hope others can learn from you? + +The thing I hope others take away from me, is to genuinely support others and tackle problems with curiosity. There used to be a time where I was always worried about being wrong, so I wouldn't get too involved. It's okay to be wrong, that's how we learn new ways to handle problems and find new ways to grow. We just all have to be open to learning and trying our best to help and support each other. diff --git a/website/docs/community/spotlight/fabiyi-opeyemi.md b/website/docs/community/spotlight/fabiyi-opeyemi.md index f26ee27910b..f67ff4aaefc 100644 --- a/website/docs/community/spotlight/fabiyi-opeyemi.md +++ b/website/docs/community/spotlight/fabiyi-opeyemi.md @@ -2,9 +2,9 @@ id: fabiyi-opeyemi title: Opeyemi Fabiyi description: | - I'm an Analytics Engineer with Data Culture, a Data Consulting firm where I use dbt regularly to help clients build quality-tested data assets. I've also got a background in financial services and supply chain. I'm passionate about helping organizations to become data-driven and I majorly use dbt for data modeling, while the other aspect of the stack is largely dependent on the client infrastructure I'm working for, so I often say I'm tool-agnostic. 😀 + I'm an Analytics Engineer with Data Culture, a Data Consulting firm where I use dbt regularly to help clients build quality-tested data assets. I've also got a background in financial services and supply chain. I'm passionate about helping organizations to become data-driven and I majorly use dbt for data modeling, while the other aspect of the stack is largely dependent on the client infrastructure I'm working for, so I often say I'm tool-agnostic. 😀 - I'm the founder of Nigeria's Young Data Professional Community. I'm also the organizer of the Lagos dbt Meetup which I started, and one of the organizers of the DataFest Africa Conference. I became an active member of the dbt Community in 2021 & spoke at Coalesce 2022. + I'm the founder of Nigeria's Young Data Professional Community. I'm also the organizer of the Lagos dbt Meetup which I started, and one of the organizers of the DataFest Africa Conference. I became an active member of the dbt Community in 2021 & spoke at Coalesce 2022. image: /img/community/spotlight/fabiyi-opeyemi.jpg pronouns: he/him location: Lagos, Nigeria @@ -16,7 +16,7 @@ socialLinks: link: https://twitter.com/Opiano_1 - name: LinkedIn link: https://www.linkedin.com/in/opeyemifabiyi/ -dateCreated: 2023-07-02 +dateCreated: 2023-11-06 hide_table_of_contents: true --- diff --git a/website/docs/community/spotlight/josh-devlin.md b/website/docs/community/spotlight/josh-devlin.md index 1a1db622209..d8a9b91c282 100644 --- a/website/docs/community/spotlight/josh-devlin.md +++ b/website/docs/community/spotlight/josh-devlin.md @@ -2,23 +2,26 @@ id: josh-devlin title: Josh Devlin description: | - After "discovering" dbt in early 2020, I joined the community and used it as a learning tool while I tried to get dbt introduced at my company. By helping others, I learned about common pitfalls, best practices, and the breadth of the tool. When it came time to implement it months later, I already felt like an expert! + Josh Devlin has a rich history of community involvement and technical expertise in both the dbt and wider analytics communities. - In December 2020 I attended the first virtual Coalesce conference, attending all 4 days across 3 time zones! I found my quirky-nerdy-purple-people, and felt at home. + Discovering dbt in early 2020, he quickly became an integral member of its community, leveraging the platform as a learning tool and aiding others along their dbt journey. Josh has helped thousands of dbt users with his advice and near-encyclopaedic knowledge of dbt. - 3 years later I had the pleasure of presenting at my first dbt Meetup in Sydney, and then at the first in-person Coalesce in New Orleans. My passion is helping people, and I'm glad that the dbt community gives me a place to do that! + Beyond the online community, he transitioned from being an attendee at the first virtual Coalesce conference in December 2020 to a presenter at the first in-person Coalesce event in New Orleans in 2022. He has also contributed to the dbt-core and dbt-snowflake codebases, helping improve the product in the most direct way. + + His continuous contributions echo his philosophy of learning through teaching, a principle that has not only enriched the dbt community but also significantly bolstered his proficiency with the tool, making him a valuable community member. + + Aside from his technical endeavors, Josh carries a heart for communal growth and an individual's ability to contribute to a larger whole, a trait mirrored in his earlier pursuits as an orchestral musician. His story is a blend of technical acumen, communal involvement, and a nuanced appreciation for the symbiotic relationship between teaching and learning, making him a notable figure in the analytics engineering space. image: /img/community/spotlight/josh-devlin.jpg pronouns: he/him location: Melbourne, Australia (but spent most of the last decade in Houston, USA) jobTitle: Senior Analytics Engineer companyName: Canva -organization: "" socialLinks: - name: Twitter link: https://twitter.com/JayPeeDevlin - name: LinkedIn link: https://www.linkedin.com/in/josh-devlin/ -dateCreated: 2023-06-27 +dateCreated: 2023-11-10 hide_table_of_contents: true --- diff --git a/website/docs/community/spotlight/karen-hsieh.md b/website/docs/community/spotlight/karen-hsieh.md index 1a5cc8c4788..5147f39ce59 100644 --- a/website/docs/community/spotlight/karen-hsieh.md +++ b/website/docs/community/spotlight/karen-hsieh.md @@ -12,7 +12,7 @@ description: | image: /img/community/spotlight/karen-hsieh.jpg pronouns: she/her location: Taipei, Taiwan -jobTitle: Director of Product & Data +jobTitle: Director of Tech & Data companyName: ALPHA Camp organization: "" socialLinks: @@ -22,7 +22,7 @@ socialLinks: link: https://www.linkedin.com/in/karenhsieh/ - name: Medium link: https://medium.com/@ijacwei -dateCreated: 2023-03-24 +dateCreated: 2023-11-04 hide_table_of_contents: true --- diff --git a/website/docs/community/spotlight/oliver-cramer.md b/website/docs/community/spotlight/oliver-cramer.md new file mode 100644 index 00000000000..194c22ddcd1 --- /dev/null +++ b/website/docs/community/spotlight/oliver-cramer.md @@ -0,0 +1,35 @@ +--- +id: oliver-cramer +title: Oliver Cramer +description: | + When I joined Aquila Capital in early 2022, I had the ModernDataStack with SqlDBM, dbt & Snowflake available. During the first half year I joined the dbt community. I have been working in the business intelligence field for many years. In 2006 I founded the first TDWI Roudtable in the DACH region. I often speak at conferences, such as the Snowflake Summit and the German TDWI conference. + I have been very involved in the data vault community for over 20 years and I do a lot of work with dbt Labs’ Sean McIntyre and Victoria Mola to promote Data Vault in EMEA. I have even travelled to Canada and China to meet data vault community members! Currently I have a group looking at the Data Vault dbt packages. The German Data Vault User Group (DDVUG) has published a sample database to test Data Warehouse Automation tools. + In addition, I founded the Analytics Engineering Northern Germany Meetup Group, which will transition into an official dbt Meetup, the Northern Germany dbt Meetup. +image: /img/community/spotlight/oliver.jpg +pronouns: he/him +location: Celle, Germany +jobTitle: Lead Data Warehouse Architect +companyName: Aquila Capital +organization: TDWI Germany +socialLinks: + - name: LinkedIn + link: https://www.linkedin.com/in/oliver-cramer/ +dateCreated: 2023-11-02 +hide_table_of_contents: true +--- + +## When did you join the dbt community and in what way has it impacted your career? + +I joined the dbt community in 2022. My current focus is on building modern data teams. There is no magic formula for structuring your analytics function. Given the pace of technological change in our industry, the structure of a data team must evolve over time. + +## What dbt community leader do you identify with? How are you looking to grow your leadership in the dbt community? + +I like working with dbt Labs' Sean McIntyre to promote Data Vault in Europe and Victoria Mola, also from dbt Labs, is always a great help when I have questions about dbt. + +## What have you learned from community members? What do you hope others can learn from you? + +I just think it's good to have a community, to be able to ask questions and get good answers. + +## Anything else interesting you want to tell us? + +Data Vault is actively looking forward to supporting the messaging that dbt Cloud (+packages) is a real alternative that works. diff --git a/website/docs/community/spotlight/sam-debruyn.md b/website/docs/community/spotlight/sam-debruyn.md new file mode 100644 index 00000000000..166adf58b09 --- /dev/null +++ b/website/docs/community/spotlight/sam-debruyn.md @@ -0,0 +1,37 @@ +--- +id: sam-debruyn +title: Sam Debruyn +description: | + I have a background of about 10 years in software engineering and moved to data engineering in 2020. Today, I lead dataroots's data & cloud unit on a technical level, allowing me to share knowledge and help multiple teams and customers, while still being hands-on every day. In 2021 and 2022, I did a lot of work on dbt-core and the dbt adapters for Microsoft SQL Server, Azure SQL, Azure Synapse, and now also Microsoft Fabric. I spoke at a few meetups and conferences about dbt and other technologies which I'm passionate about. Sharing knowledge is what drives me, so in 2023 I founded the Belgium dbt Meetup. Every meetup reached its maximum capacity ever since. +image: /img/community/spotlight/sam.jpg +pronouns: he/him +location: Heist-op-den-Berg, Belgium +jobTitle: Tech Lead Data & Cloud +companyName: dataroots +organization: "" +socialLinks: + - name: Twitter + link: https://twitter.com/s_debruyn + - name: LinkedIn + link: https://www.linkedin.com/in/samueldebruyn/ + - name: Blog + link: https://debruyn.dev/ +dateCreated: 2023-11-03 +hide_table_of_contents: true +--- + +## When did you join the dbt community and in what way has it impacted your career? + +I joined the dbt Community at the end of 2020, when we had dbt 0.18. At first, I was a bit suspicious. I thought to myself, how could a tool this simple make such a big difference? But after giving it a try, I was convinced: this is what we'll all be using for our data transformations in the future. dbt shines in its simplicity and very low learning curve. Thanks to dbt, a lot more people can become proficient in data analytics. I became a dbt evangelist, both at my job as well as in local and online data communities. I think that data holds the truth. And I think that the more people we can give access to work with data, so that they don't having to depend on others to work with complex tooling, the more we can achieve together. + +## What dbt community leader do you identify with? How are you looking to grow your leadership in the dbt community? + +It's hard to pick one person. There are lots of folks who inspired me along the way. There is Anders Swanson (known as dataders on Github), with whom I've spent countless hours discussing how we can bring two things I like together: dbt and the Microsoft SQL products. It's amazing to look back on what we achieved now that dbt Labs and Microsoft are working together to bring dbt support for Fabric and Synapse. There is also Jeremy Cohen (jerco) whose lengthy GitHub discussions bring inspiration to how you can do even more with dbt and what the future might hold. Cor Zuurmond (JCZuurmond) inspired me to start contributing to dbt-core, adapters, and related packages. He did an impressive amount of work by making dbt-spark even better, building pytest integration for dbt, and of course by bringing dbt to world's most used database: dbt-excel. + +## What have you learned from community members? What do you hope others can learn from you? + +dbt doesn't only shine when you're using it, but also under the hood. dbt's codebase is very approachable and consistently well written with code that is clean, elegant, and easy to understand. When you're thinking about a potential feature, a bugfix, or building integrations with dbt, just go to Slack or Github and see what you can do to make that happen. You can contribute by discussing potential features, adding documentation, writing code, and more. You don't need to be a Python expert to get started. + +## Anything else interesting you want to tell us? + +The dbt community is one of the biggest data communities globally, but also the most welcoming one. It's amazing how nice, friendly, and approachable everyone is. It's great to be part of this community. diff --git a/website/docs/community/spotlight/stacy-lo.md b/website/docs/community/spotlight/stacy-lo.md new file mode 100644 index 00000000000..f0b70fcc225 --- /dev/null +++ b/website/docs/community/spotlight/stacy-lo.md @@ -0,0 +1,40 @@ +--- +id: stacy-lo +title: Stacy Lo +description: | + I began my career as a data analyst, then transitioned to a few different roles in data and software development. Analytics Engineer is the best title to describe my expertise in data. + + I’ve been in the dbt Community for almost a year. In April, I shared my experience adopting dbt at the Taipei dbt Meetup, which inspired me to write technical articles. + + In Taiwan, the annual "iThome Iron Man Contest" happens in September, where participants post a technical article written in Mandarin every day for 30 consecutive days. Since no one has ever written about dbt in the contest, I'd like to be the first person, and that’s what I have been busy with for in the past couple of months. +image: /img/community/spotlight/stacy.jpg +pronouns: she/her +location: Taipei, Taiwan +jobTitle: Senior IT Developer +companyName: Teamson +socialLinks: + - name: LinkedIn + link: https://www.linkedin.com/in/olycats/ +dateCreated: 2023-11-01 +hide_table_of_contents: true +--- + +## When did you join the dbt community and in what way has it impacted your career? + +I joined dbt Slack on November 2022. It was the time our company decided to use dbt in our data architecture, so I joined the #local-taipei channel in dbt Slack and introduced myself. To my surprise, I was immediately invited to share my experience at a Taipei dbt Meetup. I just joined the community, never joined any other meetups, did not know anyone there, and was very new to dbt. + +The biggest impact to my career is that I gained a lot of visibility! I got to know a lot of great data people, and now I have one meetup presentation recorded on YouTube, 30 technical articles on iThome Iron Man Contest, and now I am featured in the dbt Community Spotlight! + +## What dbt community leader do you identify with? How are you looking to grow your leadership in the dbt community? + +Karen Hsieh is the best! She not only brought me in to the dbt Community by way of the #local-taipei channel in dbt Slack, but she also encouraged me to contribute to the community in many ways, without making me feel pressured. With her passion and leading style, Karen successfully built a friendly and diverse group of people in #local-taipei. + +I’d also like to recommend Bruno de Lima's LinkedIn posts. His 'dbt Tips of the Day' effectively delivery knowledge in a user-friendly way. In addition, I really enjoyed the dbt exam practice polls. Learning dbt can be a challenge, but Bruno makes it both easy and fun! + +## What have you learned from community members? What do you hope others can learn from you? + +I learned that there are many ways to contribute to the community, regardless of our background or skill level. Everyone has something valuable to offer, and we should never be afraid to share. Let's find our own ways to make an impact! + +## Anything else interesting you want to tell us? + +Although the #local-taipei channel in dbt Slack is not made up of many, many people, we still managed to assemble a team of 7 people to join the Iron Man Contest. We produced a total of 200 articles in 30 days in topics around dbt and data. I don’t know how many people will find them useful, but it's definitely a great start to raising awareness of dbt in Taiwan. diff --git a/website/docs/community/spotlight/sydney-burns.md b/website/docs/community/spotlight/sydney-burns.md new file mode 100644 index 00000000000..ecebd6cdec0 --- /dev/null +++ b/website/docs/community/spotlight/sydney-burns.md @@ -0,0 +1,34 @@ +--- +id: sydney-burns +title: Sydney Burns +description: | + In 2019, I started as an analytics intern at a healthcare tech startup. I learned about dbt in 2020 and joined the community to self-teach. The following year, I started using dbt professionally as a consultant, and was able to pick up various parts of the stack and dive into different implementations. That experience empowered me to strike a better balance between "best practices" and what suits a specific team best. I also spoke at Coalesce 2022, a highlight of my career! + + Now, I collaborate with other data professionals at Webflow, where focused on enhancing and scaling our data operations. I strive to share the same enthusiasm, support, and knowledge with my team that I've gained from the broader community! +image: /img/community/spotlight/sydney.jpg +pronouns: she/her +location: Panama City, FL, USA +jobTitle: Senior Analytics Engineer +companyName: Webflow +socialLinks: + - name: LinkedIn + link: https://www.linkedin.com/in/sydneyeburns/ +dateCreated: 2023-11-09 +hide_table_of_contents: true +--- + +## When did you join the dbt community and in what way has it impacted your career? + +The stack I used in my first data role was outdated and highly manual. Where I live, modern tech companies are few and far between, and I didn't have many in-person resources nor enough knowledge to realize that another world was possible at my skill level. I was thrilled to find a pocket of the Internet where similarly frustrated but creative data folks were sharing thoughtful solutions to problems I'd been struggling with! + +## What dbt community leader do you identify with? How are you looking to grow your leadership in the dbt community? + +Christine Berger was my first ever (best ever!) data colleague, and the one who first introduced me to dbt. + +There are certain qualities I've always valued in her, that I've found in many others across the community, and strive to cultivate in myself — earnestness, curiosity, creativity, and consistently doing good work with deep care. + +## What have you learned from community members? What do you hope others can learn from you? + +I spent too much time in my early career feeling scared to ask for help because I didn't want others to think I was incompetent. I'd spin my wheels on something for hours before finally asking someone to help me. + +The community has proven one thing to me time and time again: there are people here who will not only help you, but will be palpably *excited* to help you and share what they know, especially if it's clear you've made efforts to use your resources and try things on your own first. I'm one of those people now! diff --git a/website/docs/docs/build/saved-queries.md b/website/docs/docs/build/saved-queries.md index 39a4b2e52fd..a447fbb1a1a 100644 --- a/website/docs/docs/build/saved-queries.md +++ b/website/docs/docs/build/saved-queries.md @@ -6,10 +6,6 @@ sidebar_label: "Saved queries" tags: [Metrics, Semantic Layer] --- -:::info Saved queries coming soon -Saved queries isn't currently available in MetricFlow but support is coming soon. -::: - Saved queries are a way to save commonly used queries in MetricFlow. You can group metrics, dimensions, and filters that are logically related into a saved query. To define a saved query, refer to the following specification: @@ -18,9 +14,7 @@ To define a saved query, refer to the following specification: | --------- | ----------- | ---- | | `name` | The name of the metric. | Required | | `description` | The description of the metric. | Optional | -| `metrics` | The metrics included in the saved query. | Required | -| `group_bys` | The value displayed in downstream tools. | Required | -| `where` | Filter applied to the query. | Optional | +| `query_params` | The query parameters for the saved query: `metrics`, `group_by`, and `where`. | Required | The following is an example of a saved query: @@ -28,14 +22,15 @@ The following is an example of a saved query: saved_query: name: p0_booking description: Booking-related metrics that are of the highest priority. - metrics: - - bookings - - instant_bookings - group_bys: - - TimeDimension('metric_time', 'day') - - Dimension('listing__capacity_latest') - where: - - "{{ Dimension('listing__capacity_latest') }} > 3" + query_params: + metrics: + - bookings + - instant_bookings + group_bys: + - TimeDimension('metric_time', 'day') + - Dimension('listing__capacity_latest') + where: + - "{{ Dimension('listing__capacity_latest') }} > 3" ``` ### FAQs diff --git a/website/docs/docs/cloud/about-cloud/regions-ip-addresses.md b/website/docs/docs/cloud/about-cloud/regions-ip-addresses.md index 64743f85afa..cc1c2531f56 100644 --- a/website/docs/docs/cloud/about-cloud/regions-ip-addresses.md +++ b/website/docs/docs/cloud/about-cloud/regions-ip-addresses.md @@ -12,7 +12,7 @@ dbt Cloud is [hosted](/docs/cloud/about-cloud/architecture) in multiple regions | Region | Location | Access URL | IP addresses | Developer plan | Team plan | Enterprise plan | |--------|----------|------------|--------------|----------------|-----------|-----------------| | North America multi-tenant [^1] | AWS us-east-1 (N. Virginia) | cloud.getdbt.com | 52.45.144.63
54.81.134.249
52.22.161.231 | ✅ | ✅ | ✅ | -| North America Cell 1 [^1] | AWS us-east-1 (N.Virginia) | {account prefix}.us1.dbt.com | [Located in Account Settings](#locating-your-dbt-cloud-ip-addresses) | ❌ | ❌ | ❌ | +| North America Cell 1 [^1] | AWS us-east-1 (N.Virginia) | {account prefix}.us1.dbt.com | [Located in Account Settings](#locating-your-dbt-cloud-ip-addresses) | ❌ | ❌ | ✅ | | EMEA [^1] | AWS eu-central-1 (Frankfurt) | emea.dbt.com | 3.123.45.39
3.126.140.248
3.72.153.148 | ❌ | ❌ | ✅ | | APAC [^1] | AWS ap-southeast-2 (Sydney)| au.dbt.com | 52.65.89.235
3.106.40.33
13.239.155.206
| ❌ | ❌ | ✅ | | Virtual Private dbt or Single tenant | Customized | Customized | Ask [Support](/community/resources/getting-help#dbt-cloud-support) for your IPs | ❌ | ❌ | ✅ | diff --git a/website/docs/docs/cloud/cloud-cli-installation.md b/website/docs/docs/cloud/cloud-cli-installation.md index 70ae74c3df7..896b3c92f75 100644 --- a/website/docs/docs/cloud/cloud-cli-installation.md +++ b/website/docs/docs/cloud/cloud-cli-installation.md @@ -73,7 +73,9 @@ Before you begin, make sure you have [Homebrew installed](http://brew.sh/) in yo * Note that you no longer need to run the `dbt deps` command when your environment starts. This step was previously required during initialization. However, you should still run `dbt deps` if you make any changes to your `packages.yml` file. -4. After you've verified the installation, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project and use it to run [dbt commands](/reference/dbt-commands) similar to dbt Core. For example, execute `dbt compile` to compile a project using dbt Cloud and validate your models and tests. +4. Clone your repository to your local computer using `git clone`. For example, to clone a GitHub repo using HTTPS format, run `git clone https://github.com/YOUR-USERNAME/YOUR-REPOSITORY`. + +5. After cloning your repo, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project. This lets you run dbt commands like `dbt compile` to compile your project and validate models and tests. You can also add, edit, and synchronize files with your repo. @@ -102,7 +104,9 @@ Note that if you are using VS Code, you must restart it to pick up modified envi * Note that you no longer need to run the `dbt deps` command when your environment starts. This step was previously required during initialization. However, you should still run `dbt deps` if you make any changes to your `packages.yml` file. -4. After installation, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project and use it to run [dbt commands](/reference/dbt-commands) similar to dbt Core. For example, execute `dbt compile`, to compile a project using dbt Cloud and confirm that it works. +4. Clone your repository to your local computer using `git clone`. For example, to clone a GitHub repo using HTTPS format, run `git clone https://github.com/YOUR-USERNAME/YOUR-REPOSITORY`. + +5. After cloning your repo, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project. This lets you run dbt commands like `dbt compile` to compile your project and validate models and tests. You can also add, edit, and synchronize files with your repo. @@ -134,7 +138,9 @@ Advanced users can configure multiple projects to use the same Cloud CLI executa * Note that you no longer need to run the `dbt deps` command when your environment starts. This step was previously required during initialization. However, you should still run `dbt deps` if you make any changes to your `packages.yml` file. -4. After installation, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project and use it to run [dbt commands](/reference/dbt-commands) similar to dbt Core. For example, execute `dbt compile`, to compile a project using dbt Cloud and confirm that it works. +4. Clone your repository to your local computer using `git clone`. For example, to clone a GitHub repo using HTTPS format, run `git clone https://github.com/YOUR-USERNAME/YOUR-REPOSITORY`. + +5. After cloning your repo, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project. This lets you run dbt commands like `dbt compile` to compile your project and validate models and tests. You can also add, edit, and synchronize files with your repo. @@ -190,14 +196,16 @@ We recommend using virtual environments (venv) to namespace `cloud-cli`. pip3 install dbt ``` -1. (Optional) To revert back to dbt Core, first uninstall both the dbt Cloud CLI and dbt Core. Then reinstall dbt Core. +3. (Optional) To revert back to dbt Core, first uninstall both the dbt Cloud CLI and dbt Core. Then reinstall dbt Core. ```bash pip3 uninstall dbt-core dbt pip install dbt-adapter_name --force-reinstall ``` -4. After you've verified the installation, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project. You can then use it to run [dbt commands](/reference/dbt-commands) similar to dbt Core. For example, execute `dbt compile` to compile a project using dbt Cloud and validate your models and tests. +4. Clone your repository to your local computer using `git clone`. For example, to clone a GitHub repo using HTTPS format, run `git clone https://github.com/YOUR-USERNAME/YOUR-REPOSITORY`. + +5. After cloning your repo, [configure](/docs/cloud/configure-cloud-cli) the dbt Cloud CLI for your dbt Cloud project. This lets you run dbt commands like `dbt compile` to compile your project and validate models and tests. You can also add, edit, and synchronize files with your repo. diff --git a/website/docs/docs/cloud/configure-cloud-cli.md b/website/docs/docs/cloud/configure-cloud-cli.md index 35f82cff8cf..d6fca00cf25 100644 --- a/website/docs/docs/cloud/configure-cloud-cli.md +++ b/website/docs/docs/cloud/configure-cloud-cli.md @@ -76,6 +76,8 @@ Once you install the dbt Cloud CLI, you need to configure it to connect to a dbt - To find your project ID, select **Develop** in the dbt Cloud navigation menu. You can use the URL to find the project ID. For example, in `https://cloud.getdbt.com/develop/26228/projects/123456`, the project ID is `123456`. +6. You can now [use the dbt Cloud CLI](#use-the-dbt-cloud-cli) and run [dbt commands](/reference/dbt-commands) like `dbt compile`. With your repo recloned, you can add, edit, and sync files with your repo. + ### Set environment variables To set environment variables in the dbt Cloud CLI for your dbt project: diff --git a/website/docs/docs/dbt-support.md b/website/docs/docs/dbt-support.md index 513d5fff588..40968b9d763 100644 --- a/website/docs/docs/dbt-support.md +++ b/website/docs/docs/dbt-support.md @@ -5,34 +5,62 @@ pagination_next: null pagination_prev: null --- +Support for dbt is available to all users through the following channels: + +- Dedicated dbt Support team (dbt Cloud users). +- [The Community Forum](https://discourse.getdbt.com/). +- [dbt Community slack](https://www.getdbt.com/community/join-the-community/). + ## dbt Core support If you're developing on the command line (CLI) and have questions or need some help — reach out to the helpful dbt community through [the Community Forum](https://discourse.getdbt.com/) or [dbt Community slack](https://www.getdbt.com/community/join-the-community/). ## dbt Cloud support -We want to help you work through implementing and utilizing dbt Cloud at your organization. Have a question you can't find an answer to in [our docs](https://docs.getdbt.com/) or [the Community Forum](https://discourse.getdbt.com/)? Our Support team is here to `dbt help` you! -Check out our guide on [getting help](/community/resources/getting-help) - half of the problem is often knowing where to look... and how to ask good questions! +The global dbt Support team is available to dbt Cloud customers by email or in-product live chat. We want to help you work through implementing and utilizing dbt Cloud at your organization. Have a question you can't find an answer to in [our docs](https://docs.getdbt.com/) or [the Community Forum](https://discourse.getdbt.com/)? Our Support team is here to `dbt help` you! + +- **Enterprise plans** — Priority [support](#severity-level-for-enterprise-support), options for custom support coverage hours, implementation assistance, dedicated management, and dbt Labs security reviews depending on price point. +- **Developer and Team plans** — 24x5 support (no service level agreement (SLA); [contact Sales](https://www.getdbt.com/pricing/) for Enterprise plan inquiries). +- **Support team help** — Assistance with dbt Cloud questions, like project setup, login issues, error understanding, setup private packages, link to a new GitHub account, and so on. +- **Resource guide** — Check the [guide](/community/resources/getting-help) for effective help-seeking strategies. + +
+Example of common support questions +Types of dbt Cloud-related questions our Support team can assist you with, regardless of your dbt Cloud plan:

+How do I...
+ - set up a dbt Cloud project?
+ - set up a private package in dbt Cloud?
+ - configure custom branches on git repos?
+ - link dbt to a new GitHub account?

+Help! I can't...
+ - log in.
+ - access logs.
+ - update user groups.

+I need help understanding...
+ - why this run failed.
+ - why I am getting this error message in dbt Cloud?
+ - why my CI jobs are not kicking off as expected.
+
-Types of dbt Cloud-related questions our Support team can assist you with, regardless of your dbt Cloud plan: -- **How do I...** - - set up a dbt Cloud project? - - set up a private package in dbt Cloud? - - configure custom branches on git repos? - - link dbt to a new github account? -- **Help! I can't...** - - log in. - - access logs. - - update user groups. -- **I need help understanding...** - - why this run failed. - - why I am getting this error message in dbt Cloud. - - why my CI jobs are not kicking off as expected. + +## dbt Cloud Enterprise accounts -### dbt Cloud Enterprise accounts +Basic assistance with dbt project troubleshooting. +Help with errors and issues in macros, models, and dbt Labs' packages. +For strategic advice, expansion, and project setup, consult Solutions Architect and Sales Director. -For customers on a dbt Cloud Enterprise plan, we **also** offer basic assistance in troubleshooting issues with your dbt project. +For customers on a dbt Cloud Enterprise plan, we **also** offer basic assistance in troubleshooting issues with your dbt project: - **Something isn't working the way I would expect it to...** - in a macro I created... - in an incremental model I'm building... @@ -50,5 +78,20 @@ Types of questions you should ask your Solutions Architect and Sales Director: - Here is our data road map for the next year - can we talk through how dbt fits into it and what features we may not be utilizing that can help us achieve our goals? - It is time for our contract renewal, what options do I have? +### Severity level for Enterprise support + +Support tickets are assigned a severity level based on the impact of the issue on your business. The severity level is assigned by dbt Labs, and the level assigned determines the priority level of support you will receive. For specific ticket response time or other questions that relate to your Enterprise account’s SLA, please refer to your Enterprise contract. + +| Severity Level | Description | +| -------------- | ----------- | +| Severity Level 1 | Any Error which makes the use or continued use of the Subscription or material features impossible; Subscription is not operational, with no alternative available. | +| Severity Level 2 | Feature failure, without a workaround, but Subscription is operational. | +| Severity Level 3 | Feature failure, but a workaround exists. | +| Severity Level 4 | Error with low-to-no impact on Client’s access to or use of the Subscription, or Client has a general question or feature enhancement request. | + +## External help -When you need help writing SQL, reviewing the overall performance of your project, or want someone to actually help build your dbt project, check out our list of [dbt Preferred Consulting Providers](https://www.getdbt.com/ecosystem/) or our [Services](https://www.getdbt.com/dbt-labs/services/) page! +For SQL writing, project performance review, or project building, refer to dbt Preferred Consulting Providers and dbt Labs' Services. +For help writing SQL, reviewing the overall performance of your project, or want someone to actually help build your dbt project, refer to the following pages: +- List of [dbt Preferred Consulting Providers](https://www.getdbt.com/ecosystem/). +- dbt Labs' [Services](https://www.getdbt.com/dbt-labs/services/). diff --git a/website/docs/docs/deploy/source-freshness.md b/website/docs/docs/deploy/source-freshness.md index 78500416c56..2f9fe6bc007 100644 --- a/website/docs/docs/deploy/source-freshness.md +++ b/website/docs/docs/deploy/source-freshness.md @@ -13,7 +13,7 @@ dbt Cloud provides a helpful interface around dbt's [source data freshness](/doc [`dbt build`](reference/commands/build) does _not_ include source freshness checks when building and testing resources in your DAG. Instead, you can use one of these common patterns for defining jobs: - Add `dbt build` to the run step to run models, tests, and so on. - Select the **Generate docs on run** checkbox to automatically [generate project docs](/docs/collaborate/build-and-view-your-docs#set-up-a-documentation-job). -- Select the **Run on source freshness** checkbox to enable [source freshness](#checkbox) as the first to step of the job. +- Select the **Run source freshness** checkbox to enable [source freshness](#checkbox) as the first step of the job. @@ -24,7 +24,7 @@ Review the following options and outcomes: | Options | Outcomes | |--------| ------- | | **Select checkbox ** | The **Run source freshness** checkbox in your **Execution Settings** will run `dbt source freshness` as the first step in your job and won't break subsequent steps if it fails. If you wanted your job dedicated *exclusively* to running freshness checks, you still need to include at least one placeholder step, such as `dbt compile`. | -| **Add as a run step** | Add the `dbt source freshness` command to a job anywhere in your list of run steps. However, if your source data is out of date — this step will "fail', and subsequent steps will not run. dbt Cloud will trigger email notifications (if configured) based on the end state of this step.

You can create a new job to snapshot source freshness.

If you *do not* want your models to run if your source data is out of date, then it could be a good idea to run `dbt source freshness` as the first step in your job. Otherwise, we recommend adding `dbt source freshness` as the last step in the job, or creating a separate job just for this task. | +| **Add as a run step** | Add the `dbt source freshness` command to a job anywhere in your list of run steps. However, if your source data is out of date — this step will "fail", and subsequent steps will not run. dbt Cloud will trigger email notifications (if configured) based on the end state of this step.

You can create a new job to snapshot source freshness.

If you *do not* want your models to run if your source data is out of date, then it could be a good idea to run `dbt source freshness` as the first step in your job. Otherwise, we recommend adding `dbt source freshness` as the last step in the job, or creating a separate job just for this task. | diff --git a/website/docs/docs/use-dbt-semantic-layer/tableau.md b/website/docs/docs/use-dbt-semantic-layer/tableau.md index 8e6d7d8ed27..1d283023dda 100644 --- a/website/docs/docs/use-dbt-semantic-layer/tableau.md +++ b/website/docs/docs/use-dbt-semantic-layer/tableau.md @@ -12,41 +12,50 @@ The Tableau integration with the dbt Semantic Layer is a [beta feature](/docs/db The Tableau integration allows you to use worksheets to query the Semantic Layer directly and produce your dashboards with trusted data. -This integration provides a live connection to the dbt Semantic Layer through Tableau Desktop. +This integration provides a live connection to the dbt Semantic Layer through Tableau Desktop or Tableau Server. ## Prerequisites - You have [configured the dbt Semantic Layer](/docs/use-dbt-semantic-layer/setup-sl) and are using dbt v1.6 or higher. -- You must have [Tableau Desktop](https://www.tableau.com/en-gb/products/desktop) installed with version 2021.1 or greater - - Note that Tableau Online does not currently support custom connectors natively. -- Log in to Tableau Desktop using either your license or the login details you use for Tableau Server or Tableau Online. +- You must have [Tableau Desktop](https://www.tableau.com/en-gb/products/desktop) version 2021.1 and greater or Tableau Server. + - Note that Tableau Online does not currently support custom connectors natively. If you use Tableau Online, you will only be able to access the connector in Tableau Desktop. +- Log in to Tableau Desktop (with Online or Server credentials) or a license to Tableau Server - You need your dbt Cloud host, [Environment ID](/docs/use-dbt-semantic-layer/setup-sl#set-up-dbt-semantic-layer) and [service token](/docs/dbt-cloud-apis/service-tokens) to log in. This account should be set up with the dbt Semantic Layer. - You must have a dbt Cloud Team or Enterprise [account](https://www.getdbt.com/pricing) and multi-tenant [deployment](/docs/cloud/about-cloud/regions-ip-addresses). (Single-Tenant coming soon) -## Installing +## Installing the Connector 1. Download the GitHub [connector file](https://github.com/dbt-labs/semantic-layer-tableau-connector/releases/download/v1.0.2/dbt_semantic_layer.taco) locally and add it to your default folder: - - Windows: `C:\Users\\[Windows User]\Documents\My Tableau Repository\Connectors` - - Mac: `/Users/[user]/Documents/My Tableau Repository/Connectors` - - Linux: `/opt/tableau/connectors` + +| Operating system |Tableau Desktop | Tableau Server | +| ---------------- | -------------- | -------------- | +| Windows | `C:\Users\\[Windows User]\Documents\My Tableau Repository\Connectors` | `C:\Program Files\Tableau\Connectors` | +| Mac | `/Users/[user]/Documents/My Tableau Repository/Connectors` | Not applicable | +| Linux | `/opt/tableau/connectors` | `/opt/tableau/connectors` | + 2. Install the [JDBC driver](/docs/dbt-cloud-apis/sl-jdbc) to the folder based on your operating system: - Windows: `C:\Program Files\Tableau\Drivers` - Mac: `~/Library/Tableau/Drivers` - Linux: ` /opt/tableau/tableau_driver/jdbc` -3. Open Tableau Desktop and find the **dbt Semantic Layer by dbt Labs** connector on the left-hand side. -4. Connect with your Host, Environment ID, and service token information that's provided to you in your dbt Cloud Semantic Layer configuration. +3. Open Tableau Desktop or Tableau Server and find the **dbt Semantic Layer by dbt Labs** connector on the left-hand side. You may need to restart these applications for the connector to be available. +4. Connect with your Host, Environment ID, and Service Token information dbt Cloud provides during [Semantic Layer configuration](/docs/use-dbt-semantic-layer/setup-sl#:~:text=After%20saving%20it%2C%20you%27ll%20be%20provided%20with%20the%20connection%20information%20that%20allows%20you%20to%20connect%20to%20downstream%20tools). + - In Tableau Server, the authentication screen may show "User" & "Password" instead, in which case the User is the Environment ID and the password is the Service Token. ## Using the integration -Once you authenticate, the system will direct you to the data source page with all the metrics and dimensions configured in your Semantic Layer. - -- From there, go directly to a worksheet in the bottom left-hand corner. -- Then, you'll find all the metrics and dimensions that are available to query on the left-hand side of your window. +1. **Authentication** — Once you authenticate, the system will direct you to the data source page with all the metrics and dimensions configured in your dbt Semantic Layer. +2. **Access worksheet** — From there, go directly to a worksheet in the bottom left-hand corner. +3. **Access metrics and dimensions** — Then, you'll find all the metrics and dimensions that are available to query on the left side of your window. Visit the [Tableau documentation](https://help.tableau.com/current/pro/desktop/en-us/gettingstarted_overview.htm) to learn more about how to use Tableau worksheets and dashboards. +### Publish from Tableau Desktop to Tableau Server + +- **From Desktop to Server** — Like any Tableau workflow, you can publish your workbook from Tableau Desktop to Tableau Server. For step-by-step instructions, visit Tableau's [publishing guide](https://help.tableau.com/current/pro/desktop/en-us/publish_workbooks_share.htm). + + ## Things to note - All metrics use the "SUM" aggregation type, and this can't be altered. The dbt Semantic Layer controls the aggregation type and it is intentionally fixed. Keep in mind that the underlying aggregation in the dbt Semantic Layer might not be "SUM" (even though "SUM" is Tableau's default). @@ -64,9 +73,9 @@ The following Tableau features aren't supported at this time, however, the dbt S - Updating the data source page - Using "Extract" mode to view your data - Unioning Tables -- Writing Custom SQL +- Writing Custom SQL / Initial SQL - Table Extensions -- Cross Database Joins +- Cross-Database Joins - All functions in Analysis --> Create Calculated Field - Filtering on a Date Part time dimension for a Cumulative metric type - Changing your date dimension to use "Week Number" diff --git a/website/docs/reference/artifacts/run-results-json.md b/website/docs/reference/artifacts/run-results-json.md index dd92a9c4e53..5b3549db55b 100644 --- a/website/docs/reference/artifacts/run-results-json.md +++ b/website/docs/reference/artifacts/run-results-json.md @@ -3,7 +3,7 @@ title: "Run results JSON file" sidebar_label: "Run results" --- -**Current schema**: [`v4`](https://schemas.getdbt.com/dbt/run-results/v4/index.html) +**Current schema**: [`v5`](https://schemas.getdbt.com/dbt/run-results/v5/index.html) **Produced by:** [`build`](/reference/commands/build) diff --git a/website/docs/terms/data-warehouse.md b/website/docs/terms/data-warehouse.md index 2c64fbaa7b7..cf6f5de3d20 100644 --- a/website/docs/terms/data-warehouse.md +++ b/website/docs/terms/data-warehouse.md @@ -75,7 +75,7 @@ Because all of your data is located in the same place, it allows for faster repo ## Data warehouse vs data lake -A data lake is a system where you store, process, and query unstructured, semi-structured, and structured data at almost any scale. The main difference between a data warehouse and a data lake is the type and way data is stored. Data warehouses contain structured data that is meant to organize data for analytics use. Data lakes can contain pretty much any kind of data—structured or unstructured—and data is usually left it its raw format until it's ready to use. Compare that to data warehouses, whose primary goal is to be a place for data teams to store both raw and transformed, usable data. +A data lake is a system where you store, process, and query unstructured, semi-structured, and structured data at almost any scale. The main difference between a data warehouse and a data lake is the type and way data is stored. Data warehouses contain structured data that is meant to organize data for analytics use. Data lakes can contain pretty much any kind of data—structured or unstructured—and data is usually left in its raw format until it's ready to use. Compare that to data warehouses, whose primary goal is to be a place for data teams to store both raw and transformed, usable data. ## Conclusion diff --git a/website/snippets/core-versions-table.md b/website/snippets/core-versions-table.md index 71e11974a56..f1241d8301b 100644 --- a/website/snippets/core-versions-table.md +++ b/website/snippets/core-versions-table.md @@ -12,11 +12,3 @@ | [**v1.0**](/docs/dbt-versions/core-upgrade/upgrading-to-v1.0) ⚠️ | Dec 3, 2021 | Deprecated ⛔️ | Deprecated ⛔️ | | **v0.X** ⛔️ | (Various dates) | Deprecated ⛔️ | Deprecated ⛔️ | _*All versions of dbt Core since v1.0 are available in dbt Cloud until further notice. Versions that are EOL do not receive any fixes. For the best support, we recommend upgrading to a version released within the past 12 months._ -### Planned future releases - -_Future release dates are tentative and subject to change._ - -| dbt Core | Planned Release | Critical & dbt Cloud Support Until | -|----------|-----------------|-------------------------------------| -| **v1.8** | _Jan 2024_ | _Jan 2025_ | -| **v1.9** | _Apr 2024_ | _Apr 2025_ | diff --git a/website/src/components/communitySpotlightList/index.js b/website/src/components/communitySpotlightList/index.js index b72d640b74d..6885f5ff2ac 100644 --- a/website/src/components/communitySpotlightList/index.js +++ b/website/src/components/communitySpotlightList/index.js @@ -11,7 +11,7 @@ const communityDescription = "The dbt Community is where analytics engineering l // This date determines where the 'Previously on the Spotlight" text will show. // Any spotlight members with a 'dateCreated' field before this date // will be under the 'Previously..' header. -const currentSpotlightDate = new Date('2023-06-01') +const currentSpotlightDate = new Date('2023-10-31') function CommunitySpotlightList({ spotlightData }) { const { siteConfig } = useDocusaurusContext() diff --git a/website/static/img/blog/2023-11-06-differentiate-prod-and-staging-environments/data-landscape.excalidraw b/website/static/img/blog/2023-11-06-differentiate-prod-and-staging-environments/data-landscape.excalidraw new file mode 100644 index 00000000000..be8a0923345 --- /dev/null +++ b/website/static/img/blog/2023-11-06-differentiate-prod-and-staging-environments/data-landscape.excalidraw @@ -0,0 +1,1008 @@ +{ + "type": "excalidraw", + "version": 2, + "source": "https://excalidraw.com", + "elements": [ + { + "type": "rectangle", + "version": 129, + "versionNonce": 1482751856, + "isDeleted": false, + "id": "Udy5rK-Jz8k0Fq4imQCvd", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 341.8627251519098, + "y": 39.92541164822043, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 2156.810506184896, + "height": 1036.2360975477432, + "seed": 1146131484, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163923, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 93, + "versionNonce": 432336784, + "isDeleted": false, + "id": "yFoHv_ZLVYq5DdwJxTXrQ", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 393.7163289388021, + "y": 248.74700927734375, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 142.6879425048828, + "height": 70, + "seed": 1947174180, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163923, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Data \nWarehouse", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Data \nWarehouse", + "lineHeight": 1.25, + "baseline": 60 + }, + { + "type": "text", + "version": 147, + "versionNonce": 82809200, + "isDeleted": false, + "id": "18XKDb5pYJYJQPYEshmg4", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 411.73432668050134, + "y": 485.4708455403644, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 106.65194702148438, + "height": 35, + "seed": 574631460, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163923, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "git repo", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "git repo", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "text", + "version": 72, + "versionNonce": 815824272, + "isDeleted": false, + "id": "5eUI6A7oSEvd69NrXYNoc", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 398.70032246907556, + "y": 803.185655381944, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 132.71995544433594, + "height": 35, + "seed": 1782580380, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163923, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "dbt Cloud", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "dbt Cloud", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "rectangle", + "version": 138, + "versionNonce": 98296688, + "isDeleted": false, + "id": "L_y_veh-MeHyKFX1eH_jc", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 625.8938259548611, + "y": 154.95136854383676, + "strokeColor": "#f08c00", + "backgroundColor": "transparent", + "width": 506.8489583333335, + "height": 875.4567464192709, + "seed": 89476252, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163923, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 353, + "versionNonce": 1088048016, + "isDeleted": false, + "id": "cXSP5cBcW7nCrji0UWwUB", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1247.2498236762153, + "y": 154.95136854383676, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "width": 506.8489583333335, + "height": 875.4567464192709, + "seed": 303420452, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 211, + "versionNonce": 158201200, + "isDeleted": false, + "id": "Zx2HStRZKGZ9rinR0kE5E", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1868.892550998264, + "y": 155.0846964518229, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "width": 506.8489583333335, + "height": 875.4567464192709, + "seed": 650869924, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 91, + "versionNonce": 78272912, + "isDeleted": false, + "id": "epO5kSyuGRV5wTUD-s9zZ", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 853.561743842231, + "y": 97.15853542751734, + "strokeColor": "#f08c00", + "backgroundColor": "transparent", + "width": 51.79998779296875, + "height": 35, + "seed": 2015553052, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Dev", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dev", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "text", + "version": 209, + "versionNonce": 887998320, + "isDeleted": false, + "id": "fT31nBE0B8HbloZlX-nDt", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1484.1716715494792, + "y": 97.15853542751734, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "width": 33.2919921875, + "height": 35, + "seed": 549760924, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "CI", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "CI", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "text", + "version": 184, + "versionNonce": 793290640, + "isDeleted": false, + "id": "eTKqHyL2wEJwRjyzONlcj", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 2091.321043226454, + "y": 97.15853542751734, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "width": 61.991973876953125, + "height": 35, + "seed": 1462334492, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Prod", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Prod", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "rectangle", + "version": 96, + "versionNonce": 1151555952, + "isDeleted": false, + "id": "VhROTjE1abDd9ZOeAMg-U", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 689.6759711371528, + "y": 201.00466579861114, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 376.7974175347222, + "height": 165.48468695746527, + "seed": 2047365540, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 141, + "versionNonce": 1290614160, + "isDeleted": false, + "id": "k5MJxECeWuQJb8SwV3oVW", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 721.2427775065105, + "y": 248.74700927734375, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 313.3758544921875, + "height": 70, + "seed": 1555453724, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Dev DB\n(user-specific schemas)", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dev DB\n(user-specific schemas)", + "lineHeight": 1.25, + "baseline": 60 + }, + { + "type": "rectangle", + "version": 184, + "versionNonce": 36425616, + "isDeleted": false, + "id": "BO6Wxrm4rZ1QDt8vBFRFl", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 1293.0316162109375, + "y": 201.0046657986111, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 376.7974175347222, + "height": 165.48468695746527, + "seed": 334336668, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413166096, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 284, + "versionNonce": 621357968, + "isDeleted": false, + "id": "Xavgjps0qvZVKUHlsPVna", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 1317.1822781032986, + "y": 248.74700927734375, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 330.65185546875, + "height": 70, + "seed": 1180229404, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413169453, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "QA DB\n(temporary PR schemas)", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "QA DB\n(temporary PR schemas)", + "lineHeight": 1.25, + "baseline": 60 + }, + { + "type": "rectangle", + "version": 284, + "versionNonce": 886029680, + "isDeleted": false, + "id": "oDdg4x6QABrYXglaDBIHt", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 1926.055840386285, + "y": 201.0046657986111, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 376.7974175347222, + "height": 165.48468695746527, + "seed": 576422428, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 376, + "versionNonce": 254349712, + "isDeleted": false, + "id": "iTxeg4gQp5KRDrzokIgmt", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 1973.012624104818, + "y": 248.74700927734375, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 282.88385009765625, + "height": 70, + "seed": 1079828124, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Prod DB\n(production schemas)", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Prod DB\n(production schemas)", + "lineHeight": 1.25, + "baseline": 60 + }, + { + "type": "text", + "version": 139, + "versionNonce": 550932336, + "isDeleted": false, + "id": "HQeJiZeuOVrvP9ru2C-78", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 689.5203925238716, + "y": 467.98152669270837, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 379.5958251953125, + "height": 70, + "seed": 508113948, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "branches:\nfeature branches from main", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "branches:\nfeature branches from main", + "lineHeight": 1.25, + "baseline": 60 + }, + { + "type": "text", + "version": 125, + "versionNonce": 1764777872, + "isDeleted": false, + "id": "M7ejyx8utxANmCPivcWvL", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 1370.0543535020618, + "y": 485.48152669270837, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 261.2398986816406, + "height": 35, + "seed": 558908580, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "PRs targeting main", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "PRs targeting main", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "text", + "version": 27, + "versionNonce": 1211310448, + "isDeleted": false, + "id": "QmOKeCjEaTMIfbw46sNFl", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 2041.1730711195205, + "y": 485.48152669270837, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 162.2879180908203, + "height": 35, + "seed": 672916900, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "branch: main", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "branch: main", + "lineHeight": 1.25, + "baseline": 25 + }, + { + "type": "rectangle", + "version": 355, + "versionNonce": 1629351312, + "isDeleted": false, + "id": "L8G-_VdBlPmtNgQKn0G2x", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 649.1752794053821, + "y": 426.521769205729, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 1692.284138997396, + "height": 153.18637424045136, + "seed": 1687815964, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 110, + "versionNonce": 976057200, + "isDeleted": false, + "id": "rUcnW6bo9uKCXl1tVfZXO", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 668.4320305718317, + "y": 397.55624728732636, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 89.83990478515625, + "height": 25, + "seed": 1724197028, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 20, + "fontFamily": 1, + "text": "dbt_repo", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "dbt_repo", + "lineHeight": 1.25, + "baseline": 18 + }, + { + "type": "rectangle", + "version": 552, + "versionNonce": 1613347728, + "isDeleted": false, + "id": "1L7lF8fe7tHoTO95AB_6Z", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 649.1752794053821, + "y": 666.7112833658852, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 1704.8221164279514, + "height": 306.15851508246516, + "seed": 147107236, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 290, + "versionNonce": 1561167216, + "isDeleted": false, + "id": "br8j-OyjfCajGYHkvT2_0", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 668.4320305718317, + "y": 635.5079413519964, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 176.5398406982422, + "height": 25, + "seed": 1051154724, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 20, + "fontFamily": 1, + "text": "dbt Cloud Project", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "dbt Cloud Project", + "lineHeight": 1.25, + "baseline": 18 + }, + { + "type": "rectangle", + "version": 84, + "versionNonce": 1753991568, + "isDeleted": false, + "id": "HaZZKdXMOfsniJsylOZZA", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 698.8494194878472, + "y": 706.6618109809027, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 365.6057400173611, + "height": 232.40898980034729, + "seed": 1118957596, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 144, + "versionNonce": 236672880, + "isDeleted": false, + "id": "GVw8HsZ3jf_eN3qat8EnV", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 752.6179436577692, + "y": 726.0786539713541, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 256.78790283203125, + "height": 175, + "seed": 36319388, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Env Name:\nDevelopment (IDE)\n\nJobs:\nnone", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Env Name:\nDevelopment (IDE)\n\nJobs:\nnone", + "lineHeight": 1.25, + "baseline": 165 + }, + { + "type": "rectangle", + "version": 306, + "versionNonce": 1971066768, + "isDeleted": false, + "id": "25b7C18GbdjocbHu7mNFv", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1272.3475477430557, + "y": 697.7114122178818, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 456.6535101996529, + "height": 232.40898980034729, + "seed": 503421476, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 321, + "versionNonce": 1100933488, + "isDeleted": false, + "id": "YGODDCDk9jIVk8fCbxC-f", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1290.6323869493274, + "y": 726.2222222222222, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 420.0838317871094, + "height": 175, + "seed": 1720890788, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Env Name:\nCI\n\nJobs:\nSlim CI: feature branch > main", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Env Name:\nCI\n\nJobs:\nSlim CI: feature branch > main", + "lineHeight": 1.25, + "baseline": 165 + }, + { + "type": "rectangle", + "version": 246, + "versionNonce": 1530045840, + "isDeleted": false, + "id": "--xRdulSAOVkraMLOgPcU", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1904.9254014756943, + "y": 697.5177951388889, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 434.7832573784722, + "height": 232.40898980034729, + "seed": 807301284, + "groupIds": [], + "frameId": null, + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false + }, + { + "type": "text", + "version": 287, + "versionNonce": 585120624, + "isDeleted": false, + "id": "7C0I5zrwwMb_rw70yiGVh", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 2022.917074415419, + "y": 726.3555501302083, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 198.79991149902344, + "height": 175, + "seed": 2077277220, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 28, + "fontFamily": 1, + "text": "Env Name:\nProducation\n\nJobs:\nScheduled jobs", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Env Name:\nProducation\n\nJobs:\nScheduled jobs", + "lineHeight": 1.25, + "baseline": 165 + }, + { + "type": "text", + "version": 43, + "versionNonce": 652702608, + "isDeleted": false, + "id": "0vfDvWeVlJv5WnFpmnAXX", + "fillStyle": "hachure", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "angle": 0, + "x": 1139.5400729709202, + "y": -17.269870334201613, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "width": 561.455810546875, + "height": 45, + "seed": 2048509604, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1699413163924, + "link": null, + "locked": false, + "fontSize": 36, + "fontFamily": 1, + "text": "Organization's Data Landscape", + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Organization's Data Landscape", + "lineHeight": 1.25, + "baseline": 32 + } + ], + "appState": { + "gridSize": null, + "viewBackgroundColor": "#ffffff" + }, + "files": {} +} \ No newline at end of file diff --git a/website/static/img/blog/2023-11-06-differentiate-prod-and-staging-environments/data-landscape.png b/website/static/img/blog/2023-11-06-differentiate-prod-and-staging-environments/data-landscape.png new file mode 100644 index 00000000000..71f94531fcf Binary files /dev/null and b/website/static/img/blog/2023-11-06-differentiate-prod-and-staging-environments/data-landscape.png differ diff --git a/website/static/img/community/spotlight/alison.jpg b/website/static/img/community/spotlight/alison.jpg new file mode 100644 index 00000000000..8534145a814 Binary files /dev/null and b/website/static/img/community/spotlight/alison.jpg differ diff --git a/website/static/img/community/spotlight/dakota.jpg b/website/static/img/community/spotlight/dakota.jpg new file mode 100644 index 00000000000..3911514f9cd Binary files /dev/null and b/website/static/img/community/spotlight/dakota.jpg differ diff --git a/website/static/img/community/spotlight/oliver.jpg b/website/static/img/community/spotlight/oliver.jpg new file mode 100644 index 00000000000..e7740fefd4d Binary files /dev/null and b/website/static/img/community/spotlight/oliver.jpg differ diff --git a/website/static/img/community/spotlight/sam.jpg b/website/static/img/community/spotlight/sam.jpg new file mode 100644 index 00000000000..26d859efbe8 Binary files /dev/null and b/website/static/img/community/spotlight/sam.jpg differ diff --git a/website/static/img/community/spotlight/stacy.jpg b/website/static/img/community/spotlight/stacy.jpg new file mode 100644 index 00000000000..98b48c4a519 Binary files /dev/null and b/website/static/img/community/spotlight/stacy.jpg differ diff --git a/website/static/img/community/spotlight/sydney.jpg b/website/static/img/community/spotlight/sydney.jpg new file mode 100644 index 00000000000..1c847962cf7 Binary files /dev/null and b/website/static/img/community/spotlight/sydney.jpg differ