Spaces:
Running on CPU Upgrade
Running on CPU Upgrade
| <html lang=en dir=ltr class="docs-wrapper plugin-docs plugin-id-default docs-version-current docs-doc-page docs-doc-id-deployment/databricks-migration" data-has-hydrated=false><head><meta charset=UTF-8><meta name=generator content="Docusaurus v3.10.0"><title data-rh=true>Databricks Agent Bricks Refactoring - Summary | Open Navigator</title><meta data-rh=true name=viewport content="width=device-width, initial-scale=1.0"/><meta data-rh=true property=og:image content=https://www.communityone.com/img/docusaurus-social-card.jpg /><meta data-rh=true name=twitter:image content=https://www.communityone.com/img/docusaurus-social-card.jpg /><meta data-rh=true property=og:url content=https://www.communityone.com/docs/deployment/databricks-migration /><meta data-rh=true property=og:locale content=en /><meta data-rh=true name=docusaurus_locale content=en /><meta data-rh=true name=docsearch:language content=en /><meta data-rh=true name=keywords content="civic engagement, policy tracking, meeting minutes, nonprofit tracking, municipal government, advocacy, open data, local government"/><meta data-rh=true property=og:type content=website /><meta data-rh=true property=og:site_name content="Open Navigator"/><meta data-rh=true name=twitter:card content=summary_large_image /><meta data-rh=true name=docusaurus_version content=current /><meta data-rh=true name=docusaurus_tag content=docs-default-current /><meta data-rh=true name=docsearch:version content=current /><meta data-rh=true name=docsearch:docusaurus_tag content=docs-default-current /><meta data-rh=true property=og:title content="Databricks Agent Bricks Refactoring - Summary | Open Navigator"/><meta data-rh=true name=description content="What Was Done"/><meta data-rh=true property=og:description content="What Was Done"/><link data-rh=true rel=icon href=/img/favicon.ico /><link data-rh=true rel=canonical href=https://www.communityone.com/docs/deployment/databricks-migration /><link data-rh=true rel=alternate href=https://www.communityone.com/docs/deployment/databricks-migration hreflang=en /><link data-rh=true rel=alternate href=https://www.communityone.com/docs/deployment/databricks-migration hreflang=x-default /><script data-rh=true type=application/ld+json>{"@context":"https://schema.org","@type":"BreadcrumbList","itemListElement":[{"@type":"ListItem","item":"https://www.communityone.com/docs/for-developers","name":"Developers & Technical Users","position":1},{"@type":"ListItem","item":"https://www.communityone.com/docs/deployment/databricks-migration","name":"Databricks Agent Bricks Refactoring - Summary","position":2}]}</script><link rel=alternate type=application/rss+xml href=/blog/rss.xml title="Open Navigator RSS Feed"><link rel=alternate type=application/atom+xml href=/blog/atom.xml title="Open Navigator Atom Feed"><link rel=preconnect href=https://www.google-analytics.com><link rel=preconnect href=https://www.googletagmanager.com><script async src="https://www.googletagmanager.com/gtag/js?id=G-5EQV815915"></script><script>function gtag(){dataLayer.push(arguments)}window.dataLayer=window.dataLayer||[],gtag("js",new Date),gtag("config","G-5EQV815915",{anonymize_ip:!0})</script><link rel=stylesheet href=/assets/css/styles.c89d6b2d.css /><script src=/assets/js/runtime~main.c8fa085e.js defer></script><script src=/assets/js/main.6e24e536.js defer></script></head><body><svg style="display: none;"><defs> | |
| <symbol id=theme-svg-external-link viewBox="0 0 24 24"><path fill=currentColor d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"/></symbol> | |
| </defs></svg> | |
| <script>!function(){var t=function(){try{return new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}}()||function(){try{return window.localStorage.getItem("theme-7e9")}catch(t){}}();document.documentElement.setAttribute("data-theme",t||(window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light")),document.documentElement.setAttribute("data-theme-choice",t||"system")}(),function(){try{for(var[t,e]of new URLSearchParams(window.location.search).entries())if(t.startsWith("docusaurus-data-")){var a=t.replace("docusaurus-data-","data-");document.documentElement.setAttribute(a,e)}}catch(t){}}()</script><div id=__docusaurus><link rel=preload as=image href=/img/communityone_logo.svg /><script type=application/ld+json>{"@context":"https://schema.org","@type":"Organization","address":{"@type":"PostalAddress","addressCountry":"US","addressLocality":"Tuscaloosa","addressRegion":"AL","postalCode":"35406","streetAddress":"5617 Lakeridge Court"},"contactPoint":{"@type":"ContactPoint","availableLanguage":["English"],"contactType":"Customer Service","email":"johnbowyer@communityone.com"},"description":"Track 90,000+ jurisdictions, 1.8M nonprofits, and analyze meeting minutes with AI. The open path to everything local.","email":"johnbowyer@communityone.com","legalName":"CommunityOne","logo":"https://www.communityone.com/img/communityone_logo.svg","name":"CommunityOne","sameAs":["https://www.facebook.com/communityone","https://www.instagram.com/communityone","https://twitter.com/communityone","https://www.linkedin.com/company/communityone","https://www.youtube.com/@communityone","https://discord.gg/communityone","https://github.com/getcommunityone/open-navigator"],"url":"https://www.communityone.com"}</script><script type=application/ld+json>{"@context":"https://schema.org","@type":"WebSite","alternateName":"CommunityOne Open Navigator","description":"AI-powered civic engagement platform tracking jurisdictions, nonprofits, and government meetings","name":"Open Navigator","potentialAction":{"@type":"SearchAction","query-input":"required name=search_term_string","target":{"@type":"EntryPoint","urlTemplate":"https://www.communityone.com/search?q={search_term_string}"}},"url":"https://www.communityone.com"}</script><script type=application/ld+json>{"@context":"https://schema.org","@type":"SoftwareApplication","aggregateRating":{"@type":"AggregateRating","ratingCount":"1","ratingValue":"5"},"applicationCategory":"BusinessApplication","description":"Track 90,000+ jurisdictions, 1.8M nonprofits, and analyze meeting minutes with AI","featureList":["Track 90,000+ jurisdictions","Monitor 1.8M nonprofits","Analyze meeting minutes","Legislative bill tracking","Campaign finance data"],"name":"Open Navigator","offers":{"@type":"Offer","price":"0","priceCurrency":"USD"},"operatingSystem":"Web","screenshot":"https://www.communityone.com/img/docusaurus-social-card.jpg","softwareVersion":"1.0.0"}</script><div role=region aria-label="Skip to main content"><a class=skipToContent_fXgn href=#__docusaurus_skipToContent_fallback>Skip to main content</a></div><nav aria-label=Main class="theme-layout-navbar navbar navbar--fixed-top"><div class=navbar__inner><div class="theme-layout-navbar-left navbar__items"><button aria-label="Toggle navigation bar" aria-expanded=false class="navbar__toggle clean-btn" type=button><svg width=30 height=30 viewBox="0 0 30 30" aria-hidden=true><path stroke=currentColor stroke-linecap=round stroke-miterlimit=10 stroke-width=2 d="M4 7h22M4 15h22M4 23h22"/></svg></button><a href=https://www.communityone.com target=_self rel="noopener noreferrer" class=navbar__brand><div class=navbar__logo><img src=/img/communityone_logo.svg alt="CommunityOne Logo" class="themedComponent_mlkZ themedComponent--light_NVdE"/><img src=/img/communityone_logo.svg alt="CommunityOne Logo" class="themedComponent_mlkZ themedComponent--dark_xIcU"/></div><b class="navbar__title text--truncate">Open Navigator Home</b></a><a class="navbar__item navbar__link" href=/docs/intro>Getting Started</a><a class="navbar__item navbar__link" href=/docs/for-families>Families & Individuals</a><a class="navbar__item navbar__link" href=/docs/for-advocates>Policy Makers</a><a class="navbar__item navbar__link" href=/docs/for-developers>Developers</a><a class="navbar__item navbar__link" href=/docs/data-sources/citations>Data and Terms</a><a class="navbar__item navbar__link" href=/blog>Blog</a></div><div class="theme-layout-navbar-right navbar__items navbar__items--right"><a href=https://github.com/getcommunityone/open-navigator-for-engagement target=_blank rel="noopener noreferrer" class="navbar__item navbar__link">GitHub<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type=button disabled title="system mode" aria-label="Switch between dark and light mode (currently system mode)"><svg viewBox="0 0 24 24" width=24 height=24 aria-hidden=true class="toggleIcon_g3eP lightToggleIcon_pyhR"><path fill=currentColor d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"/></svg><svg viewBox="0 0 24 24" width=24 height=24 aria-hidden=true class="toggleIcon_g3eP darkToggleIcon_wfgR"><path fill=currentColor d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"/></svg><svg viewBox="0 0 24 24" width=24 height=24 aria-hidden=true class="toggleIcon_g3eP systemToggleIcon_QzmC"><path fill=currentColor d="m12 21c4.971 0 9-4.029 9-9s-4.029-9-9-9-9 4.029-9 9 4.029 9 9 9zm4.95-13.95c1.313 1.313 2.05 3.093 2.05 4.95s-0.738 3.637-2.05 4.95c-1.313 1.313-3.093 2.05-4.95 2.05v-14c1.857 0 3.637 0.737 4.95 2.05z"/></svg></button></div><div class=navbarSearchContainer_Bca1></div></div></div><div role=presentation class=navbar-sidebar__backdrop></div></nav><div id=__docusaurus_skipToContent_fallback class="theme-layout-main main-wrapper mainWrapper_z2l0"><div class=docsWrapper_hBAB><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type=button></button><div class=docRoot_UBD9><aside class="theme-doc-sidebar-container docSidebarContainer_YfHR"><div class=sidebarViewport_aRkj><div class=sidebar_njMd><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=true href=/docs/intro><span title="Getting Started" class=categoryLinkLabel_W154>Getting Started</span></a></div><ul class=menu__list><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class=menu__link tabindex=0 href=/docs/intro><span title=Introduction class=linkLabel_WmDU>Introduction</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class=menu__link tabindex=0 href=/docs/open-navigator><span title="Open Navigator" class=linkLabel_WmDU>Open Navigator</span></a></ul><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist" href=/docs/for-families><span title="Families & Individuals" class=categoryLinkLabel_W154>Families & Individuals</span></a><button aria-label="Collapse sidebar category 'Families & Individuals'" aria-expanded=true type=button class="clean-btn menu__caret"></button></div><ul class=menu__list><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/families/community-events><span title="Resources for Families" class=categoryLinkLabel_W154>Resources for Families</span></a></div><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class=menu__link tabindex=0 href=/docs/open-navigator><span title="Getting Started with Open Navigator" class=linkLabel_WmDU>Getting Started with Open Navigator</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class=menu__link tabindex=0 href=/docs/data-sources/citations><span title="Data and Citations" class=linkLabel_WmDU>Data and Citations</span></a></ul><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist" href=/docs/for-advocates><span title="Policy Makers & Advocates" class=categoryLinkLabel_W154>Policy Makers & Advocates</span></a><button aria-label="Collapse sidebar category 'Policy Makers & Advocates'" aria-expanded=true type=button class="clean-btn menu__caret"></button></div><ul class=menu__list><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/data-sources/overview><span title="Understanding the Data" class=categoryLinkLabel_W154>Understanding the Data</span></a></div><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/guides/political-economy><span title="Analysis & Strategy" class=categoryLinkLabel_W154>Analysis & Strategy</span></a></div><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/case-studies/tuscaloosa-complete><span title="Real-World Examples" class=categoryLinkLabel_W154>Real-World Examples</span></a></div></ul><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--active" href=/docs/for-developers><span title="Developers & Technical Users" class=categoryLinkLabel_W154>Developers & Technical Users</span></a><button aria-label="Collapse sidebar category 'Developers & Technical Users'" aria-expanded=true type=button class="clean-btn menu__caret"></button></div><ul class=menu__list><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/quickstart><span title="Setup & Installation" class=categoryLinkLabel_W154>Setup & Installation</span></a></div><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/data-sources/citations><span title="Data Sources (Technical)" class=categoryLinkLabel_W154>Data Sources (Technical)</span></a></div><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/guides/jurisdiction-setup><span title="How-To Guides" class=categoryLinkLabel_W154>How-To Guides</span></a></div><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/integrations/mcp-server><span title=Integrations class=categoryLinkLabel_W154>Integrations</span></a></div><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" role=button aria-expanded=true tabindex=0 href=/docs/deployment/databricks-apps><span title=Deployment class=categoryLinkLabel_W154>Deployment</span></a></div><ul class=menu__list><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/databricks-apps><span title="Databricks Apps Deployment Guide" class=linkLabel_WmDU>Databricks Apps Deployment Guide</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class="menu__link menu__link--active" aria-current=page tabindex=0 href=/docs/deployment/databricks-migration><span title="Databricks Agent Bricks Refactoring - Summary" class=linkLabel_WmDU>Databricks Agent Bricks Refactoring - Summary</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/quickstart-databricks><span title="Quick Start Guide - React + FastAPI Databricks App" class=linkLabel_WmDU>Quick Start Guide - React + FastAPI Databricks App</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/huggingface-spaces><span title="Hugging Face Spaces Deployment" class=linkLabel_WmDU>Hugging Face Spaces Deployment</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/oauth-providers-setup><span title="OAuth Providers Setup" class=linkLabel_WmDU>OAuth Providers Setup</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/authentication-setup><span title="Authentication Setup Guide" class=linkLabel_WmDU>Authentication Setup Guide</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/schema-migration><span title="Schema Migration Guide" class=linkLabel_WmDU>Schema Migration Guide</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/build-verification><span title="Build Verification & CI/CD" class=linkLabel_WmDU>Build Verification & CI/CD</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/variable-migration><span title="π Variable Name Migration Guide" class=linkLabel_WmDU>π Variable Name Migration Guide</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/d-drive-configuration><span title="D Drive Configuration for Large Datasets" class=linkLabel_WmDU>D Drive Configuration for Large Datasets</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/docker-troubleshooting><span title="π Docker Build Troubleshooting Guide" class=linkLabel_WmDU>π Docker Build Troubleshooting Guide</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/build-protection><span title="Build Protection & CI/CD" class=linkLabel_WmDU>Build Protection & CI/CD</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/rename-repository><span title="Rename Repository & Make Public" class=linkLabel_WmDU>Rename Repository & Make Public</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/costs><span title="π° Cost Breakdown: $0 for Data Access" class=linkLabel_WmDU>π° Cost Breakdown: $0 for Data Access</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/jurisdiction-discovery><span title="Jurisdiction Discovery - Deployment Options" class=linkLabel_WmDU>Jurisdiction Discovery - Deployment Options</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/scale><span title="π RUNNING DISCOVERY FOR ALL U.S. CITIES AND COUNTIES" class=linkLabel_WmDU>π RUNNING DISCOVERY FOR ALL U.S. CITIES AND COUNTIES</span></a><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-3 menu__list-item"><a class=menu__link tabindex=0 href=/docs/deployment/storage><span title="π° COST-EFFECTIVE STORAGE STRATEGY (Personal Budget)" class=linkLabel_WmDU>π° COST-EFFECTIVE STORAGE STRATEGY (Personal Budget)</span></a></ul><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-2 menu__list-item menu__list-item--collapsed"><div class=menu__list-item-collapsible><a class="categoryLink_byQd menu__link menu__link--sublist menu__link--sublist-caret" role=button aria-expanded=false tabindex=0 href=/docs/development/database-setup><span title=Development class=categoryLinkLabel_W154>Development</span></a></div></ul></ul></nav></div></div></aside><main class=docMainContainer_TBSr><div class="container padding-top--md padding-bottom--lg"><div class=row><div class="col docItemCol_VOVn"><div class=docItemContainer_Djhp><article><nav class="theme-doc-breadcrumbs breadcrumbsContainer_Z_bl" aria-label=Breadcrumbs><ul class=breadcrumbs><li class=breadcrumbs__item><a aria-label="Home page" class=breadcrumbs__link href=/><svg viewBox="0 0 24 24" class=breadcrumbHomeIcon_YNFT><path d="M10 19v-5h4v5c0 .55.45 1 1 1h3c.55 0 1-.45 1-1v-7h1.7c.46 0 .68-.57.33-.87L12.67 3.6c-.38-.34-.96-.34-1.34 0l-8.36 7.53c-.34.3-.13.87.33.87H5v7c0 .55.45 1 1 1h3c.55 0 1-.45 1-1z" fill=currentColor /></svg></a><li class=breadcrumbs__item><a class=breadcrumbs__link href=/docs/for-developers><span>Developers & Technical Users</span></a><li class=breadcrumbs__item><span class=breadcrumbs__link>Deployment</span><li class="breadcrumbs__item breadcrumbs__item--active"><span class=breadcrumbs__link>Databricks Agent Bricks Refactoring - Summary</span></ul></nav><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type=button class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Databricks Agent Bricks Refactoring - Summary</h1></header> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=what-was-done>What Was Done<a href=#what-was-done class=hash-link aria-label="Direct link to What Was Done" title="Direct link to What Was Done" translate=no>β</a></h2> | |
| <p>This system has been refactored to support <strong>Databricks Agent Bricks</strong> (Mosaic AI Agent Framework), enabling production-ready deployment on Databricks with full governance, monitoring, and scalability.</p> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=new-files-created>New Files Created<a href=#new-files-created class=hash-link aria-label="Direct link to New Files Created" title="Direct link to New Files Created" translate=no>β</a></h2> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=1-core-agent-infrastructure>1. <strong>Core Agent Infrastructure</strong><a href=#1-core-agent-infrastructure class=hash-link aria-label="Direct link to 1-core-agent-infrastructure" title="Direct link to 1-core-agent-infrastructure" translate=no>β</a></h3> | |
| <ul> | |
| <li class=""> | |
| <p><code>agents/mlflow_base.py</code> - MLflow Pyfunc base classes for agents</p> | |
| <ul> | |
| <li class=""><code>MLflowAgentBase</code>: Base class with tracing, Model Serving compatibility</li> | |
| <li class=""><code>MLflowChainAgent</code>: LangChain integration with automatic logging</li> | |
| <li class="">Automatic signature inference</li> | |
| <li class="">Unity Catalog registration methods</li> | |
| <li class="">Model Serving deployment helpers</li> | |
| </ul> | |
| </li> | |
| <li class=""> | |
| <p><code>agents/mlflow_classifier.py</code> - Production classifier agent</p> | |
| <ul> | |
| <li class="">Hybrid keyword + LLM classification</li> | |
| <li class="">MLflow tracing for all calls</li> | |
| <li class="">Unity Catalog ready</li> | |
| <li class="">Can be deployed to Model Serving</li> | |
| <li class="">Includes registration script</li> | |
| </ul> | |
| </li> | |
| </ul> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=2-deployment--operations>2. <strong>Deployment & Operations</strong><a href=#2-deployment--operations class=hash-link aria-label="Direct link to 2-deployment--operations" title="Direct link to 2-deployment--operations" translate=no>β</a></h3> | |
| <ul> | |
| <li class=""> | |
| <p><code>databricks/deployment.py</code> - Deployment automation</p> | |
| <ul> | |
| <li class=""><code>AgentDeploymentManager</code> class</li> | |
| <li class="">Register agents to Unity Catalog</li> | |
| <li class="">Deploy to Model Serving endpoints</li> | |
| <li class="">Multi-agent endpoints with traffic splitting</li> | |
| <li class="">Endpoint testing and monitoring</li> | |
| <li class="">Auto-scaling configuration</li> | |
| </ul> | |
| </li> | |
| <li class=""> | |
| <p><code>databricks/evaluation.py</code> - Quality assurance</p> | |
| <ul> | |
| <li class=""><code>AgentEvaluator</code> class</li> | |
| <li class="">Automated evaluation pipelines</li> | |
| <li class="">A/B testing between versions</li> | |
| <li class="">Metrics: accuracy, precision, recall, F1, latency</li> | |
| <li class="">Confusion matrix generation</li> | |
| <li class="">Feedback loop integration with Delta Lake</li> | |
| </ul> | |
| </li> | |
| </ul> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=3-interactive-development>3. <strong>Interactive Development</strong><a href=#3-interactive-development class=hash-link aria-label="Direct link to 3-interactive-development" title="Direct link to 3-interactive-development" translate=no>β</a></h3> | |
| <ul> | |
| <li class=""> | |
| <p><code>databricks/notebooks/01_agent_bricks_quickstart.py</code> - Databricks notebook</p> | |
| <ul> | |
| <li class="">Step-by-step deployment guide</li> | |
| <li class="">Local testing examples</li> | |
| <li class="">Unity Catalog registration</li> | |
| <li class="">Model Serving deployment</li> | |
| <li class="">Evaluation examples</li> | |
| <li class="">Delta Lake queries</li> | |
| <li class="">Monitoring and observability</li> | |
| </ul> | |
| </li> | |
| <li class=""> | |
| <p><code>databricks/README.md</code> - Comprehensive documentation</p> | |
| <ul> | |
| <li class="">Architecture diagrams</li> | |
| <li class="">Deployment workflows</li> | |
| <li class="">API usage examples</li> | |
| <li class="">Cost considerations</li> | |
| <li class="">Troubleshooting guide</li> | |
| <li class="">Best practices</li> | |
| </ul> | |
| </li> | |
| </ul> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=4-dependencies>4. <strong>Dependencies</strong><a href=#4-dependencies class=hash-link aria-label="Direct link to 4-dependencies" title="Direct link to 4-dependencies" translate=no>β</a></h3> | |
| <ul> | |
| <li class="">Updated <code>requirements-cpu.txt</code> with:<!-- --> | |
| <ul> | |
| <li class=""><code>mlflow>=2.10.0</code> - MLflow tracking and serving</li> | |
| <li class=""><code>databricks-agents>=0.1.0</code> - Agent Framework</li> | |
| <li class=""><code>databricks-vectorsearch>=0.22.0</code> - Vector search</li> | |
| <li class=""><code>langgraph>=0.0.20</code> - Stateful agent graphs</li> | |
| <li class=""><code>databricks-sdk>=0.18.0</code> - Databricks API client</li> | |
| </ul> | |
| </li> | |
| </ul> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=5-updated-existing-files>5. <strong>Updated Existing Files</strong><a href=#5-updated-existing-files class=hash-link aria-label="Direct link to 5-updated-existing-files" title="Direct link to 5-updated-existing-files" translate=no>β</a></h3> | |
| <ul> | |
| <li class=""><code>README.md</code> - Added Databricks Agent Bricks section</li> | |
| <li class=""><code>install.sh</code> - Detects and uses <code>requirements-cpu.txt</code></li> | |
| </ul> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=key-features-added>Key Features Added<a href=#key-features-added class=hash-link aria-label="Direct link to Key Features Added" title="Direct link to Key Features Added" translate=no>β</a></h2> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=1-mlflow-integration>1. <strong>MLflow Integration</strong><a href=#1-mlflow-integration class=hash-link aria-label="Direct link to 1-mlflow-integration" title="Direct link to 1-mlflow-integration" translate=no>β</a></h3> | |
| <p>β Automatic tracing of all agent calls | |
| β LLM request/response logging | |
| β Metrics tracking (latency, tokens, cost) | |
| β Experiment tracking and versioning | |
| β Model registry integration</p> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=2-unity-catalog-governance>2. <strong>Unity Catalog Governance</strong><a href=#2-unity-catalog-governance class=hash-link aria-label="Direct link to 2-unity-catalog-governance" title="Direct link to 2-unity-catalog-governance" translate=no>β</a></h3> | |
| <p>β Centralized model registration | |
| β Permissions and access control | |
| β Data lineage tracking | |
| β Version management | |
| β Tag-based organization</p> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=3-model-serving>3. <strong>Model Serving</strong><a href=#3-model-serving class=hash-link aria-label="Direct link to 3-model-serving" title="Direct link to 3-model-serving" translate=no>β</a></h3> | |
| <p>β REST API endpoints | |
| β Auto-scaling (scale-to-zero capable) | |
| β A/B testing with traffic splitting | |
| β Multi-agent pipelines | |
| β Monitoring and alerting</p> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=4-evaluation-framework>4. <strong>Evaluation Framework</strong><a href=#4-evaluation-framework class=hash-link aria-label="Direct link to 4-evaluation-framework" title="Direct link to 4-evaluation-framework" translate=no>β</a></h3> | |
| <p>β Automated quality metrics | |
| β Regression detection | |
| β Version comparison | |
| β Confusion matrices | |
| β Feedback loop from production</p> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=5-production-ready>5. <strong>Production Ready</strong><a href=#5-production-ready class=hash-link aria-label="Direct link to 5-production-ready" title="Direct link to 5-production-ready" translate=no>β</a></h3> | |
| <p>β CPU-only compatibility (no GPU needed) | |
| β Enterprise monitoring | |
| β Cost optimization (keyword filtering before LLM) | |
| β Error handling and retries | |
| β Comprehensive logging</p> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=deployment-architecture>Deployment Architecture<a href=#deployment-architecture class=hash-link aria-label="Direct link to Deployment Architecture" title="Direct link to Deployment Architecture" translate=no>β</a></h2> | |
| <div class="language-text codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-text codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token plain">ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β Databricks Workspace β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β ββββββββββββββββββββ ββββββββββββββββββββββ β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β Unity Catalog ββββββββ€ MLflow Tracking β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β - Policy Class. β β - Experiments β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β - Sentiment An. β β - Traces β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β - Advocacy Gen. β β - Metrics β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β ββββββββββ¬ββββββββββ ββββββββββββββββββββββ β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β βΌ β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β ββββββββββββββββββββββββββββββββββββββββββββ β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β Model Serving Endpoints β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β ββββββββββββββ βββββββββββββββββββββββ β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β β Classifier β β Sentiment Analyzer β β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β β (Small) β β (Small) β β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β β Scale-to-0 β β Scale-to-0 β β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β ββββββββββββββ βββββββββββββββββββββββ β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β βββββββββββββββ¬βββββββββββββββββββββββββββββ β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">β β β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain">ββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββββββββ</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> βΌ</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> ββββββββββββββββββ</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> β External API β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> β FastAPI App β</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> ββββββββββββββββββ</span><br/></div></code></pre></div></div> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=usage-examples>Usage Examples<a href=#usage-examples class=hash-link aria-label="Direct link to Usage Examples" title="Direct link to Usage Examples" translate=no>β</a></h2> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=register-agent-to-unity-catalog>Register Agent to Unity Catalog<a href=#register-agent-to-unity-catalog class=hash-link aria-label="Direct link to Register Agent to Unity Catalog" title="Direct link to Register Agent to Unity Catalog" translate=no>β</a></h3> | |
| <div class="language-python codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-python codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token keyword" style=color:#00009f>from</span><span class="token plain"> agents</span><span class="token punctuation" style=color:#393A34>.</span><span class="token plain">mlflow_classifier </span><span class="token keyword" style=color:#00009f>import</span><span class="token plain"> PolicyClassifierAgent</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"></span><span class="token keyword" style=color:#00009f>from</span><span class="token plain"> databricks</span><span class="token punctuation" style=color:#393A34>.</span><span class="token plain">deployment </span><span class="token keyword" style=color:#00009f>import</span><span class="token plain"> AgentDeploymentManager</span><br/></div><div class=token-line style=color:#393A34><span class="token plain" style=display:inline-block></span><br/></div><div class=token-line style=color:#393A34><span class="token plain">manager </span><span class="token operator" style=color:#393A34>=</span><span class="token plain"> AgentDeploymentManager</span><span class="token punctuation" style=color:#393A34>(</span><span class="token punctuation" style=color:#393A34>)</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain" style=display:inline-block></span><br/></div><div class=token-line style=color:#393A34><span class="token plain">version </span><span class="token operator" style=color:#393A34>=</span><span class="token plain"> manager</span><span class="token punctuation" style=color:#393A34>.</span><span class="token plain">register_agent</span><span class="token punctuation" style=color:#393A34>(</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> agent_class</span><span class="token operator" style=color:#393A34>=</span><span class="token plain">PolicyClassifierAgent</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> agent_name</span><span class="token operator" style=color:#393A34>=</span><span class="token string" style=color:#e3116c>"policy_classifier"</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> description</span><span class="token operator" style=color:#393A34>=</span><span class="token string" style=color:#e3116c>"Classifies documents for oral health topics"</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> tags</span><span class="token operator" style=color:#393A34>=</span><span class="token punctuation" style=color:#393A34>{</span><span class="token string" style=color:#e3116c>"team"</span><span class="token punctuation" style=color:#393A34>:</span><span class="token plain"> </span><span class="token string" style=color:#e3116c>"advocacy"</span><span class="token punctuation" style=color:#393A34>}</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"></span><span class="token punctuation" style=color:#393A34>)</span><br/></div></code></pre></div></div> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=deploy-to-model-serving>Deploy to Model Serving<a href=#deploy-to-model-serving class=hash-link aria-label="Direct link to Deploy to Model Serving" title="Direct link to Deploy to Model Serving" translate=no>β</a></h3> | |
| <div class="language-python codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-python codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token plain">endpoint_url </span><span class="token operator" style=color:#393A34>=</span><span class="token plain"> manager</span><span class="token punctuation" style=color:#393A34>.</span><span class="token plain">deploy_agent</span><span class="token punctuation" style=color:#393A34>(</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> agent_name</span><span class="token operator" style=color:#393A34>=</span><span class="token string" style=color:#e3116c>"policy_classifier"</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> endpoint_name</span><span class="token operator" style=color:#393A34>=</span><span class="token string" style=color:#e3116c>"policy-classifier-prod"</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> workload_size</span><span class="token operator" style=color:#393A34>=</span><span class="token string" style=color:#e3116c>"Small"</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> scale_to_zero</span><span class="token operator" style=color:#393A34>=</span><span class="token boolean" style=color:#36acaa>True</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"></span><span class="token punctuation" style=color:#393A34>)</span><br/></div></code></pre></div></div> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=evaluate-agent>Evaluate Agent<a href=#evaluate-agent class=hash-link aria-label="Direct link to Evaluate Agent" title="Direct link to Evaluate Agent" translate=no>β</a></h3> | |
| <div class="language-python codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-python codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token keyword" style=color:#00009f>from</span><span class="token plain"> databricks</span><span class="token punctuation" style=color:#393A34>.</span><span class="token plain">evaluation </span><span class="token keyword" style=color:#00009f>import</span><span class="token plain"> AgentEvaluator</span><br/></div><div class=token-line style=color:#393A34><span class="token plain" style=display:inline-block></span><br/></div><div class=token-line style=color:#393A34><span class="token plain">evaluator </span><span class="token operator" style=color:#393A34>=</span><span class="token plain"> AgentEvaluator</span><span class="token punctuation" style=color:#393A34>(</span><span class="token string" style=color:#e3116c>"policy_classifier"</span><span class="token punctuation" style=color:#393A34>)</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain" style=display:inline-block></span><br/></div><div class=token-line style=color:#393A34><span class="token plain">metrics </span><span class="token operator" style=color:#393A34>=</span><span class="token plain"> evaluator</span><span class="token punctuation" style=color:#393A34>.</span><span class="token plain">evaluate_classifier</span><span class="token punctuation" style=color:#393A34>(</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> model_uri</span><span class="token operator" style=color:#393A34>=</span><span class="token string" style=color:#e3116c>"models:/main.agents.policy_classifier/1"</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> test_documents</span><span class="token operator" style=color:#393A34>=</span><span class="token plain">test_docs</span><span class="token punctuation" style=color:#393A34>,</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> ground_truth</span><span class="token operator" style=color:#393A34>=</span><span class="token plain">labels</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"></span><span class="token punctuation" style=color:#393A34>)</span><span class="token plain"></span><br/></div><div class=token-line style=color:#393A34><span class="token plain" style=display:inline-block></span><br/></div><div class=token-line style=color:#393A34><span class="token plain"></span><span class="token keyword" style=color:#00009f>print</span><span class="token punctuation" style=color:#393A34>(</span><span class="token string-interpolation string" style=color:#e3116c>f"Accuracy: </span><span class="token string-interpolation interpolation punctuation" style=color:#393A34>{</span><span class="token string-interpolation interpolation">metrics</span><span class="token string-interpolation interpolation punctuation" style=color:#393A34>.</span><span class="token string-interpolation interpolation">accuracy</span><span class="token string-interpolation interpolation punctuation" style=color:#393A34>:</span><span class="token string-interpolation interpolation format-spec">.2%</span><span class="token string-interpolation interpolation punctuation" style=color:#393A34>}</span><span class="token string-interpolation string" style=color:#e3116c>"</span><span class="token punctuation" style=color:#393A34>)</span><br/></div></code></pre></div></div> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=invoke-via-api>Invoke via API<a href=#invoke-via-api class=hash-link aria-label="Direct link to Invoke via API" title="Direct link to Invoke via API" translate=no>β</a></h3> | |
| <div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-bash codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token plain">curl -X POST https://workspace.cloud.databricks.com/serving-endpoints/policy-classifier-prod/invocations \</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> -H "Authorization: Bearer $DATABRICKS_TOKEN" \</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> -H "Content-Type: application/json" \</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> -d '{</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> "dataframe_records": [{</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> "document_id": "doc_001",</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> "title": "Meeting",</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> "content": "Fluoride discussion..."</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> }]</span><br/></div><div class=token-line style=color:#393A34><span class="token plain"> }'</span><br/></div></code></pre></div></div> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=benefits>Benefits<a href=#benefits class=hash-link aria-label="Direct link to Benefits" title="Direct link to Benefits" translate=no>β</a></h2> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=before-custom-implementation>Before (Custom Implementation)<a href=#before-custom-implementation class=hash-link aria-label="Direct link to Before (Custom Implementation)" title="Direct link to Before (Custom Implementation)" translate=no>β</a></h3> | |
| <ul> | |
| <li class="">β Manual deployment and versioning</li> | |
| <li class="">β No built-in observability</li> | |
| <li class="">β Limited scalability</li> | |
| <li class="">β No governance or lineage</li> | |
| <li class="">β Manual evaluation pipelines</li> | |
| <li class="">β Complex monitoring setup</li> | |
| </ul> | |
| <h3 class="anchor anchorTargetStickyNavbar_Vzrq" id=after-databricks-agent-bricks>After (Databricks Agent Bricks)<a href=#after-databricks-agent-bricks class=hash-link aria-label="Direct link to After (Databricks Agent Bricks)" title="Direct link to After (Databricks Agent Bricks)" translate=no>β</a></h3> | |
| <ul> | |
| <li class="">β One-command deployment</li> | |
| <li class="">β Automatic tracing and logging</li> | |
| <li class="">β Auto-scaling Model Serving</li> | |
| <li class="">β Unity Catalog governance</li> | |
| <li class="">β Built-in evaluation framework</li> | |
| <li class="">β Enterprise monitoring included</li> | |
| </ul> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=cost-optimization>Cost Optimization<a href=#cost-optimization class=hash-link aria-label="Direct link to Cost Optimization" title="Direct link to Cost Optimization" translate=no>β</a></h2> | |
| <p>The refactored system includes several cost optimizations:</p> | |
| <ol> | |
| <li class=""><strong>Hybrid Classification</strong>: Uses keyword matching before expensive LLM calls</li> | |
| <li class=""><strong>Scale-to-Zero</strong>: Endpoints scale down when idle</li> | |
| <li class=""><strong>Batch Processing</strong>: Supports bulk document classification</li> | |
| <li class=""><strong>Caching</strong>: Frequently requested results can be cached</li> | |
| <li class=""><strong>Small Workloads</strong>: Starts with small endpoints, scales on demand</li> | |
| </ol> | |
| <p>Estimated cost: <strong>~$0.10-0.50/hour for active endpoints</strong> (much less with scale-to-zero)</p> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=next-steps>Next Steps<a href=#next-steps class=hash-link aria-label="Direct link to Next Steps" title="Direct link to Next Steps" translate=no>β</a></h2> | |
| <ol> | |
| <li class=""> | |
| <p><strong>Deploy to Databricks</strong>:</p> | |
| <div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-bash codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token plain">python -m databricks.deployment</span><br/></div></code></pre></div></div> | |
| </li> | |
| <li class=""> | |
| <p><strong>Run Evaluation</strong>:</p> | |
| <div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style=--prism-color:#393A34;--prism-background-color:#f6f8fa><div class=codeBlockContent_QJqH><pre tabindex=0 class="prism-code language-bash codeBlock_bY9V thin-scrollbar" style=color:#393A34;background-color:#f6f8fa><code class=codeBlockLines_e6Vv><div class=token-line style=color:#393A34><span class="token plain">python -m databricks.evaluation</span><br/></div></code></pre></div></div> | |
| </li> | |
| <li class=""> | |
| <p><strong>Test in Notebook</strong>: Open <code>databricks/notebooks/01_agent_bricks_quickstart.py</code></p> | |
| </li> | |
| <li class=""> | |
| <p><strong>Monitor Production</strong>: Set up alerts in Databricks UI</p> | |
| </li> | |
| <li class=""> | |
| <p><strong>Add Feedback Loop</strong>: Collect corrections and retrain</p> | |
| </li> | |
| </ol> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=migration-path>Migration Path<a href=#migration-path class=hash-link aria-label="Direct link to Migration Path" title="Direct link to Migration Path" translate=no>β</a></h2> | |
| <p>For existing users:</p> | |
| <ol> | |
| <li class="">β <strong>Standalone mode still works</strong> - No breaking changes to existing code</li> | |
| <li class="">π <strong>Gradual migration</strong> - Can use both modes simultaneously</li> | |
| <li class="">βοΈ <strong>Databricks optional</strong> - Only needed for production scale</li> | |
| <li class="">π― <strong>Choose your path</strong>:<!-- --> | |
| <ul> | |
| <li class="">Small projects: Use standalone mode</li> | |
| <li class="">Production/Enterprise: Use Databricks Agent Bricks</li> | |
| </ul> | |
| </li> | |
| </ol> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=questions>Questions?<a href=#questions class=hash-link aria-label="Direct link to Questions?" title="Direct link to Questions?" translate=no>β</a></h2> | |
| <ul> | |
| <li class="">See <a class="" href=/docs/deployment/databricks/README.md><code>databricks/README.md</code></a> for detailed docs</li> | |
| <li class="">Run <code>databricks/notebooks/01_agent_bricks_quickstart.py</code> for hands-on tutorial</li> | |
| <li class="">Check examples in <code>databricks/deployment.py</code> and <code>databricks/evaluation.py</code></li> | |
| </ul> | |
| <h2 class="anchor anchorTargetStickyNavbar_Vzrq" id=summary>Summary<a href=#summary class=hash-link aria-label="Direct link to Summary" title="Direct link to Summary" translate=no>β</a></h2> | |
| <p>This refactoring transforms the Oral Health Policy Pulse from a standalone multi-agent system into a <strong>production-ready, enterprise-grade application</strong> that leverages Databricks' full stack for AI governance, deployment, and monitoring. The system now has:</p> | |
| <ul> | |
| <li class="">π’ <strong>Enterprise deployment</strong> via Model Serving</li> | |
| <li class="">π <strong>Automatic observability</strong> with MLflow tracing</li> | |
| <li class="">π <strong>Data governance</strong> through Unity Catalog</li> | |
| <li class="">π <strong>Quality assurance</strong> with evaluation framework</li> | |
| <li class="">π° <strong>Cost optimization</strong> with scale-to-zero and hybrid approach</li> | |
| <li class="">π <strong>Production readiness</strong> out of the box</li> | |
| </ul> | |
| <p>All while maintaining backward compatibility with the standalone mode! π</div><footer class="theme-doc-footer docusaurus-mt-lg"><div class="row margin-top--sm theme-doc-footer-edit-meta-row"><div class="col noPrint_WFHX"><a href=https://github.com/getcommunityone/open-navigator-for-engagement/tree/main/website/docs/deployment/databricks-migration.md target=_blank rel="noopener noreferrer" class=theme-edit-this-page><svg fill=currentColor height=20 width=20 viewBox="0 0 40 40" class=iconEdit_Z9Sw aria-hidden=true><g><path d="m34.5 11.7l-3 3.1-6.3-6.3 3.1-3q0.5-0.5 1.2-0.5t1.1 0.5l3.9 3.9q0.5 0.4 0.5 1.1t-0.5 1.2z m-29.5 17.1l18.4-18.5 6.3 6.3-18.4 18.4h-6.3v-6.2z"/></g></svg>Edit this page</a></div><div class="col lastUpdated_JAkA"></div></div></footer></article><nav class="docusaurus-mt-lg pagination-nav" aria-label="Docs pages"><a class="pagination-nav__link pagination-nav__link--prev" href=/docs/deployment/databricks-apps><div class=pagination-nav__sublabel>Previous</div><div class=pagination-nav__label>Databricks Apps Deployment Guide</div></a><a class="pagination-nav__link pagination-nav__link--next" href=/docs/deployment/quickstart-databricks><div class=pagination-nav__sublabel>Next</div><div class=pagination-nav__label>Quick Start Guide - React + FastAPI Databricks App</div></a></nav></div></div><div class="col col--3"><div class="tableOfContents_bqdL thin-scrollbar theme-doc-toc-desktop"><ul class="table-of-contents table-of-contents__left-border"><li><a href=#what-was-done class="table-of-contents__link toc-highlight">What Was Done</a><li><a href=#new-files-created class="table-of-contents__link toc-highlight">New Files Created</a><ul><li><a href=#1-core-agent-infrastructure class="table-of-contents__link toc-highlight">1. <strong>Core Agent Infrastructure</strong></a><li><a href=#2-deployment--operations class="table-of-contents__link toc-highlight">2. <strong>Deployment & Operations</strong></a><li><a href=#3-interactive-development class="table-of-contents__link toc-highlight">3. <strong>Interactive Development</strong></a><li><a href=#4-dependencies class="table-of-contents__link toc-highlight">4. <strong>Dependencies</strong></a><li><a href=#5-updated-existing-files class="table-of-contents__link toc-highlight">5. <strong>Updated Existing Files</strong></a></ul><li><a href=#key-features-added class="table-of-contents__link toc-highlight">Key Features Added</a><ul><li><a href=#1-mlflow-integration class="table-of-contents__link toc-highlight">1. <strong>MLflow Integration</strong></a><li><a href=#2-unity-catalog-governance class="table-of-contents__link toc-highlight">2. <strong>Unity Catalog Governance</strong></a><li><a href=#3-model-serving class="table-of-contents__link toc-highlight">3. <strong>Model Serving</strong></a><li><a href=#4-evaluation-framework class="table-of-contents__link toc-highlight">4. <strong>Evaluation Framework</strong></a><li><a href=#5-production-ready class="table-of-contents__link toc-highlight">5. <strong>Production Ready</strong></a></ul><li><a href=#deployment-architecture class="table-of-contents__link toc-highlight">Deployment Architecture</a><li><a href=#usage-examples class="table-of-contents__link toc-highlight">Usage Examples</a><ul><li><a href=#register-agent-to-unity-catalog class="table-of-contents__link toc-highlight">Register Agent to Unity Catalog</a><li><a href=#deploy-to-model-serving class="table-of-contents__link toc-highlight">Deploy to Model Serving</a><li><a href=#evaluate-agent class="table-of-contents__link toc-highlight">Evaluate Agent</a><li><a href=#invoke-via-api class="table-of-contents__link toc-highlight">Invoke via API</a></ul><li><a href=#benefits class="table-of-contents__link toc-highlight">Benefits</a><ul><li><a href=#before-custom-implementation class="table-of-contents__link toc-highlight">Before (Custom Implementation)</a><li><a href=#after-databricks-agent-bricks class="table-of-contents__link toc-highlight">After (Databricks Agent Bricks)</a></ul><li><a href=#cost-optimization class="table-of-contents__link toc-highlight">Cost Optimization</a><li><a href=#next-steps class="table-of-contents__link toc-highlight">Next Steps</a><li><a href=#migration-path class="table-of-contents__link toc-highlight">Migration Path</a><li><a href=#questions class="table-of-contents__link toc-highlight">Questions?</a><li><a href=#summary class="table-of-contents__link toc-highlight">Summary</a></ul></div></div></div></div></main></div></div></div><footer class="theme-layout-footer footer footer--dark"><div class="container container-fluid"><div class="row footer__links"><div class="theme-layout-footer-column col footer__col"><div class=footer__title>Documentation</div><ul class="footer__items clean-list"><li class=footer__item><a class=footer__link-item href=/docs/intro>Getting Started</a><li class=footer__item><a class=footer__link-item href=/docs/data-sources/citations>Citations & Data Sources</a><li class=footer__item><a class=footer__link-item href=/docs/data-sources/overview>Data Sources</a><li class=footer__item><a class=footer__link-item href=/docs/for-developers>For Developers</a></ul></div><div class="theme-layout-footer-column col footer__col"><div class=footer__title>Resources</div><ul class="footer__items clean-list"><li class=footer__item><a href=https://www.communityone.com target=_blank rel="noopener noreferrer" class=footer__link-item>Launch Open Navigator<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://github.com/getcommunityone/open-navigator-for-engagement target=_blank rel="noopener noreferrer" class=footer__link-item>GitHub<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://www.groundvue.org/ target=_blank rel="noopener noreferrer" class=footer__link-item>GroundVue (Partner)<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a></ul></div><div class="theme-layout-footer-column col footer__col"><div class=footer__title>Community</div><ul class="footer__items clean-list"><li class=footer__item><a href=https://www.instagram.com/getcommunityone/ target=_blank rel="noopener noreferrer" class=footer__link-item>Instagram<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://www.facebook.com/getcommunityone target=_blank rel="noopener noreferrer" class=footer__link-item>Facebook<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://x.com/getcommunityone/ target=_blank rel="noopener noreferrer" class=footer__link-item>X (Twitter)<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://www.linkedin.com/company/getcommunityone target=_blank rel="noopener noreferrer" class=footer__link-item>LinkedIn<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://www.youtube.com/@getcommunityone target=_blank rel="noopener noreferrer" class=footer__link-item>YouTube<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a><li class=footer__item><a href=https://discord.gg/uH6Dytek target=_blank rel="noopener noreferrer" class=footer__link-item>Discord<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a></ul></div><div class="theme-layout-footer-column col footer__col"><div class=footer__title>Legal</div><ul class="footer__items clean-list"><li class=footer__item><a class=footer__link-item href=/docs/legal/privacy-policy>Privacy Policy</a><li class=footer__item><a class=footer__link-item href=/docs/legal/terms-of-service>Terms of Service</a><li class=footer__item><a class=footer__link-item href=/docs/legal/data-provider-terms>Data Provider Terms</a></ul></div><div class="theme-layout-footer-column col footer__col"><div class=footer__title>More</div><ul class="footer__items clean-list"><li class=footer__item><a class=footer__link-item href=/blog>Blog</a><li class=footer__item><a href=https://github.com/getcommunityone/open-navigator-for-engagement/blob/main/LICENSE target=_blank rel="noopener noreferrer" class=footer__link-item>License (MIT)<svg width=13.5 height=13.5 aria-label="(opens in new tab)" class=iconExternalLink_nPIU><use href=#theme-svg-external-link /></svg></a></ul></div></div><div class="footer__bottom text--center"><div class=footer__copyright>Copyright Β© 2026 Community One. Built with Docusaurus.</div></div></div></footer></div></body> |