ID.nl logo
Zo zet je in een handomdraai je eigen virtual private server op
© Abdul Qaiyoom
Huis

Zo zet je in een handomdraai je eigen virtual private server op

Wil je een server op internet met volledig beheer over het besturingssysteem, bijvoorbeeld voor testen en ontwikkelen? Dan is een virtual private server (VPS) een heel handige optie. Je hebt ze in een handomdraai operationeel en je kunt je als root-gebruiker uitleven met al je probeersels. De prijzen zijn erg schappelijk door de gedeelde processorkracht.

Na het lezen van dit artikel is je duidelijk waar je rekening mee moet houden als je een VPS wilt gaan gebruiken. Denk bijvoorbeeld aan:

  • Hoelang je van plan bent de server te gaan gebruiken
  • Welk besturingssysteem je wilt installeren
  • Welk platform jouw voorkeur heeft
  • Of je met containers wilt werken
  • Welke extra software je eventueel wilt installeren

Ook interessant: Eigen cloud maken met ownCloud

Voor een server op internet in eigen beheer was een dedicated server lange tijd de enige optie. Maar ze hebben best wat nadelen, onder meer dat ze duur zijn, de hardware onderhoud nodig heeft en dat de rekenkracht maar zelden efficiënt wordt benut. Virtualisatie heeft de hostingwereld flink opgeschud. Steeds vaker wordt een dedicated server ingeruild voor een virtual private server (VPS). Je kunt zo’n systeem gebruiken zoals elke server: met een besturingssysteem naar voorkeur, wat vaak Linux zal zijn.

Een systeem wordt hierbij gedeeld met andere virtuele servers. Dat hoeft geen groot bezwaar te zijn. Een typische server zal immers zelden volop worden belast. Het delen van een server zorgt voor een veel hogere efficiëntie en drukt de prijzen daarom enorm. Voor minder dan 5 euro per maand heb je een basissysteem met bijvoorbeeld een gedeelde processorkern en 1 gigabyte geheugen. Zit je erom verlegen, dan heb je ze meestal met een paar klikken online. Maar hoe kies je een VPS en waar moet je op letten? Wat zijn de meest praktische besturingssystemen? En hoe begin je met het inrichten van zo’n systeem? In dit artikel helpen we je op weg.

Wat voor VPS?

In dit artikel gaan we uit van een VPS met gedeelde processorkracht. Providers gebruiken hier geen gangbare termen voor. Dat maakt het zoeken en vergelijken wat lastiger. Het bedrijf DigitalOcean noemt deze VPS’en bijvoorbeeld droplets, Vultr gebruikt de term Cloud Compute, bij Linode vind je ze onder de noemer shared cpu en bij Contabo heten ze Cloud VPS. Wat je krijgt, komt op papier wel overeen, al kunnen de prestaties erg uiteenlopen (zie het kader ‘Prestaties van je VPS’). Hoewel veel providers de laatste jaren de stijgende kosten hebben doorberekend aan gebruikers, zijn de meeste instapproducten heel laag geprijsd en daarmee echte publiekstrekkers. Bij veel providers kun je voor een VPS niet alleen voor gedeelde processorkracht kiezen, maar ook voor gereserveerde of ‘dedicated’ processorkernen, die dus niet worden gedeeld. Voor testen en ontwikkelen zal dat niet snel nodig zijn. Bovendien wordt, gelet op de veel hogere prijs, een ‘echte’ dedicated server dan meestal weer interessanter.

Een VPS vind je bij DigitalOcean onder de naam droplet.

Prestaties van je VPS De uiteindelijke prestaties van een VPS kunnen erg uiteenlopen en die zijn niet heel goed te voorspellen. Sommige providers doen het beter dan andere. Er bestaande talloze benchmarks die mensen gebruiken om de prestaties te kunnen meten en onderling vergelijken, waaronder bench, nench en VPSbench.

Zulke scripts laten doorgaans nuttige systeeminformatie zien over bijvoorbeeld de processor en het geheugen. Ook testen ze bijvoorbeeld de netwerkprestaties, de tijd die de processor nodig heeft voor een bepaalde set taken en de vaak onderbelichte lees- en schijfprestaties van de opslag.

Je eigen ervaringen zullen uiteindelijk vaak de doorslag geven. Gelukkig zit je zelden lang vast aan een keuze.

Met een benchmark kun je de prestaties van je VPS meten.

Korte of lange looptijd?

Het is handig om vooraf over de gewenste looptijd na de denken. Gaat het om een heel korte periode, dan zijn providers als Vultr, Linode, DigitalOcean en Hetzner interessant. Hier kun je een VPS ook prima voor een paar dagen huren. Achteraf, op het moment dat je de VPS verwijdert, kijken ze naar het aantal uren dat de VPS in die maand actief was, waardoor je dus eigenlijk maar een deel van het maandtarief betaalt. Hoeveel uur je daadwerkelijk op de VPS hebt gewerkt, is daarbij overigens niet relevant.

Als je een VPS langere tijd gaat gebruiken, zal dit minder belangrijk zijn. Je hebt dan ook wat meer opties. Zo huur je bij Strato Duitsland bijvoorbeeld al vanaf 1 euro per maand een bescheiden virtuele Linux-server, met een looptijd van twaalf maanden. De oplevering is echter niet direct. Als het niet bevalt, kun je de server binnen dertig dagen opzeggen (zoals alle producten van Strato overigens) en je geld terug krijgen, dus het risico is bescheiden.

Voor onder andere Vultr en DigitalOcean kun je eenvoudig promotiecodes vinden waarmee je alles met korting of zelfs zonder enige kosten kunt proberen gedurende één of twee maanden.

Voor deze VPS zijn 21 uur na het aanmaken 20 dollarcent aan kosten gemaakt.

Klein beginnen

Een belangrijk voordeel van een VPS, naast de vaak lagere kosten, is een veel betere schaalbaarheid. Je kunt meestal licht beginnen en later opschalen naar een zwaardere server. Controleer dit wel bij de betreffende provider als dat belangrijk voor je is!

Meestal raden we aan bescheiden te beginnen. Je kunt namelijk vaak wel upgraden, maar niet zomaar downgraden naar een eenvoudiger pakket. Dat kan dan alleen door het verwijderen van de oude server en het opzetten van de nieuwe server. Je begint dan weer met een schone lei, tenzij je bijvoorbeeld via een back-up of snapshot de omgeving kunt herstellen.

Met welke specificaties je begint, zal vooral afhankelijk zijn van het doel van de server. Naast bijvoorbeeld het aantal processorkernen en de geheugencapaciteit is het ook raadzaam te controleren of er een bandbreedtelimiet is. Bij normaal gebruik zul je er ver onder blijven, maar misschien heb je toepassingen op het oog die veel verkeer zullen genereren.

We beginnen eenvoudig met het goedkoopste pakket van Vultr. Let op dat de btw vaak pas achteraf in het winkelmandje erbij opgeteld wordt.

Of je gaat toch voor een fysieke server

Je vindt een grote selectie bij Bol.com

Beperkte ondersteuning Van ondersteuning mag je niet te veel verwachten bij een VPS die je voor een habbekrats opzet. De wachttijd is vaak lang en meestal hoef je geen reactie te verwachten buiten kantooruren. Dat is vooral lastig als er een technisch probleem is buiten jouw macht om. Als het om bijvoorbeeld softwareperikelen gaat, zul je die zelf moeten oplossen. Maar dat ben je wellicht al gewend. Gelukkig is internet ruim voorzien van installatiegidsen over internettoepassingen zoals Nginx, php en MySQL. Vooral de instructies van DigitalOcean worden vaak genoemd.

Besturingssysteem

Bij de keuze van een besturingssysteem heb je heel veel opties, die wel per provider verschillen. Al zien we veel gemeenschappelijke keuzes zoals Ubuntu, Debian, ArchLinux, CentOS en Fedora. Uiteindelijk zal je keuze afhangen van de toepassingen die je gaat gebruiken, en jouw eigen kennis en ervaring.

Als je voor wat testdoeleinden een VPS gaat opzetten, gebruik dan vooral iets waar je al mee hebt leren werken. Voor veel mensen is dat Debian of Ubuntu. Je profiteert dan ook van de grootste repository’s met opensource-software. De keuze voor bijvoorbeeld het lichte en efficiënte Alpine Linux is een sprong in het diepe als je er niet mee hebt gewerkt. De relatief kleine besparing in processor- en geheugengebruik is de moeite niet waard voor een doorsnee gebruiker.

Bij sommige providers kun je een iso-bestand uploaden als basis voor je VPS. Die optie is handig voor maatwerk of als je met een exotisch besturingssysteem wilt werken. Bovendien kun je via een iso-bestand met een recenter image werken dan de provider standaard aanbiedt. Onder meer bij Vultr en DigitalOcean kun je een met een specifiek iso-bestand werken.

Controleer welke besturingssystemen de provider ondersteunt voor je VPS.

Ontwikkelingen besturingssystemen

Het is slim de ontwikkelingen wat betreft besturingssystemen in de gaten te houden. Werk je graag met het op Red Hat Enterprise Linux (RHEL) gebaseerde CentOS, dan zijn de opensource-distributies AlmaLinux en Rocky Linux tegenwoordig interessante alternatieven, wetende dat CentOS uit wordt gefaseerd.

Een andere ontwikkeling is het groeiende gebruik van containers, zoals Docker of Kubernetes. Ook op een VPS kun je doorgaans prima met die technieken werken. Er zijn sinds enkele jaren voor dat doel geoptimaliseerde besturingssystemen (zie het kader ‘Werken met containers op je VPS’). Bij enkele providers kun je die selecteren. Al werkt zoiets als Docker natuurlijk ook prima onder Debian of Ubuntu.

Een besturingssysteem als AlmaLinux is een interessant alternatief voor CentOS.

Werken met containers op je VPS Een VPS is in feite een virtuele machine die draait op een zogeheten hypervisor. In de hostingwereld is dat vaak een KVM (Kernel-based Virtual Machine). Je kunt over het algemeen geen hypervisor in een VPS installeren, ook wel geneste virtualisatie genoemd. Wel kun je doorgaans met containers werken in je VPS, zoals Docker en Kubernetes. Wil je die richting op, dan kun je eventueel een besturingssysteem overwegen dat volledig is gericht op het werken met containers, zoals RancherOS of Fedora CoreOS.

Deze besturingssystemen worden ook wel microbesturingssystemen genoemd, omdat ze erg minimalistisch zijn. Ze bieden net genoeg om met containers te werken. Je kunt je daardoor volledig richten op het beheren van containers in plaats van het onderhouden van het besturingssysteem.

Wil je toch met een hypervisor werken? Een dedicated server is een goede kandidaat voor een hypervisor, zoals Proxmox VE. Daarin kun je met zowel Linux-containers (LXC) als virtuele machines op basis van KVM werken.

Sommige besturingssystemen zijn volledig gericht op het werken met containers.

Extra software

Een VPS wordt doorgaans ‘kaal’ opgeleverd, zonder aanvullende pakketten. Omdat je volledige root-toegang hebt, kun je alle vereisten zelf installeren. Soms kun je wel aanvullende pakketten kiezen. Een controlepaneel zoals Plesk, Webmin of het vaak prijzige cPanel kan erg praktisch zijn voor het beheer van je server.

Wil je voor het web gaan ontwikkelen, dan kun je bijvoorbeeld een zogenoemde LEMP-stack laten installeren, wat staat voor de combinatie van Linux met de webserver Nginx, de databaseserver MySQL en de programmeeromgeving PHP. Wil je jouw VPS instellen als privé-VPN, zodat je bijvoorbeeld wat veiliger kunt surfen op openbare netwerken, dan is dat ook een mooie toepassing. WireGuard is daarbij een populaire optie. Maar ook bijvoorbeeld UTunnel VPN en WarpSpeed VPN kun je bij Vultr laten installeren.

Soms kun je extra software op de VPS laten installeren.

Keuze platform

Als je denkt dat je alle opties hebt gezien, krijg je bij het inrichten van een VPS soms nog meer keuzes. Zo kun je bij Vultr bij het inrichten van je VPS, in dit geval Cloud Compute genoemd, AMD of Intel als platform kiezen. En bij Intel heb je nog de keuze tussen High Performance, High Frequency en Regular Performance.

Ook andere providers geven je hier vaak een keuze in. Zo kun je bij Hetzner sinds 2023 naast de gangbare x86-architectuur ook voor hosting kiezen op basis van Ampere Ultra-processors die de arm64-architectuur gebruiken. De hostingpakketten hebben een zeer goede prijs-prestatieverhouding, geholpen door de hoge efficiëntie van deze processors. Een minpunt is dat sommige software, bijvoorbeeld bepaalde Docker-containers, niet voor deze architectuur beschikbaar is.

Soms kun je ook nog het platform kiezen waarop de VPS is gebaseerd.

Aanvraagprocedure

De aanvraagprocedure verschilt uiteraard per provider, maar als je weet wat je nodig hebt, zijn de stappen meestal niet lastig meer. Bij Vultr maak je eerst een account aan en voeg je een betaalmethode toe. Als je via je omgeving naar Products gaat, kun je onder Instances met de optie Deploy Server een nieuwe VPS inrichten. We kiezen de optie Cloud Compute. Als platform kiezen we Intel met de optie High Frequency. Daaronder kun je een locatie kiezen. Vultr heeft datacenters wereldwijd, waaronder Amsterdam. Die optie kiezen we hier. Andere opties dicht bij huis zijn bijvoorbeeld Frankfurt en Londen.

Als besturingssysteem kiezen we Ubuntu 22.04 LTS, maar je kunt ook uit veel andere opties of extra software kiezen. Hierna kies je de omvang van de server. Als voorbeeld kiezen we 32 GB opslag, 1 vCPU, 1 GB geheugen en 1 TB bandbreedte.

Let op de eventuele extra’s die standaard zijn aangevinkt, maar die je misschien niet nodig hebt. Zo staat bij Vultr standaard de optie voor automatische back-ups aan, waar je ook extra voor betaalt. Ten slotte wordt met Deploy Now de server aangemaakt. Dit gaat geheel automatisch en vrijwel direct daarna kun je al gebruikmaken van de VPS. Maar niet alle providers hebben een volledig geautomatiseerd proces.

Na de aanvraagprocedure kun je vrijwel direct met je VPS aan de slag.

Toegang tot de server

Via je omgeving kun je op het tabblad Overview de details van de server opvragen. Eventueel open je hier een console voor het beheer van je software, zoals de installatie van software. Maar je kunt natuurlijk ook inloggen met ssh en je favoriete client. Bij de aanvraag zag je wellicht de optie om ssh-sleutels toe te voegen. Maar je kunt ook met gebruikersnaam en wachtwoord inloggen. Het standaard toegekende wachtwoord voor het root-account vind je bij de serverdetails. Uiteraard is het raadzaam dit direct na het inloggen te veranderen.

Je hoeft je bij het beheer van je server natuurlijk niet te beperken tot het root-account. Het is zelfs veiliger om een extra account te maken dat je aan de sudo-groep toevoegt. Dat account gebruik je dan voortaan om in te loggen en voor veel taken op het systeem. Onder Settings lees je verder onder meer het IPv4-adres af om mee te verbinden. Verder kun je eventueel upgraden naar een zwaarder pakket (maar niet downgraden). Je ziet ook een mogelijkheid een ander besturingssysteem te installeren, die kies je gewoon uit een lijst. Daardoor wordt uiteraard wel alle data op de server gewist.

In je persoonlijke omgeving kun je alle relevante details over je VPS vinden.

Firewall voor toegangsbeperkingen

Bij de VPS van Vultr is toegang via ssh op poort 22 direct mogelijk, bijvoorbeeld met een programma als PuTTY. Handig om te weten, is dat er een firewall actief is die standaard alleen het verkeer naar die poort toestaat. De firewall zit andere toepassingen mogelijk in de weg.

Wil je bijvoorbeeld een webserver zoals Nginx gebruiken, dan moet je de toegang tot poorten 80 en/of 443 dus expliciet openzetten. Bij Ubuntu wordt UFW (Uncomplicated Firewall) als firewall gebruikt. Met het commando ufw status zie je in dat geval welke poorten zijn toegestaan. Zoals gezegd, is dat initieel alleen de ssh-poort 22. Met dit commando voeg je poort 80 voor http-verkeer eenvoudig toe:

ufw allow 80/tcp

En met dit commando ook poort 443 voor versleutelde verbindingen:

ufw allow 443/tcp

Andere providers zullen wellicht ook standaard een firewall gebruiken.

Via onder andere ssh kun je volledige toegang verkrijgen tot de server.
▼ Volgende artikel
SSD vs. HDD: waarom is een SSD zo veel sneller dan een harde schijf?
© arinahabich
Huis

SSD vs. HDD: waarom is een SSD zo veel sneller dan een harde schijf?

Waarom start een computer met een SSD binnen enkele seconden op, terwijl een oude harde schijf blijft ratelen? Het vervangen van een HDD door een SSD is de beste upgrade voor een trage laptop of pc. We leggen in dit artikel uit waar die enorme snelheidswinst vandaan komt en wat het fundamentele verschil is tussen deze twee opslagtechnieken.

Iedereen die zijn computer of laptop een tweede leven wil geven, krijgt vaak hetzelfde advies: vervang de oude harde schijf door een SSD. De snelheidswinst is direct merkbaar bij het opstarten en het openen van programma's. Maar waar komt dat enorme verschil in prestaties vandaan? Het antwoord ligt in de fundamentele technologie die schuilgaat onder de behuizing van deze opslagmedia.

De vertraging van mechanische onderdelen

Om te begrijpen waarom een Solid State Drive (SSD) zo snel is, moeten we eerst kijken naar de beperkingen van de traditionele harde schijf (HDD). Een HDD werkt met magnetische roterende platen. Dat kun je vergelijken met een geavanceerde platenspeler. Wanneer je een bestand opent, moet een fysieke lees- en schrijfkop zich naar de juiste plek op de draaiende schijf verplaatsen om de data op te halen. Dat fysieke proces kost tijd, wat we latentie noemen. Hoe meer de data op de schijf verspreid staat, hoe vaker de kop heen en weer moet bewegen en wachten tot de juiste sector onder de naald doordraait. Dit mechanische aspect is de grootste vertragende factor in traditionele opslag.

©Claudio Divizia

Flashgeheugen en directe gegevensoverdracht

Een SSD rekent definitief af met deze wachttijden omdat er geen bewegende onderdelen in de behuizing zitten. De naam 'Solid State' verwijst hier ook naar; het is een vast medium zonder rammelende componenten. In plaats van magnetische platen gebruikt een SSD zogenoemd NAND-flashgeheugen. Dat is vergelijkbaar met de technologie in een usb-stick, maar dan veel sneller en betrouwbaarder. Omdat de data op microchips wordt opgeslagen, is de toegang tot bestanden volledig elektronisch. Er hoeft geen schijf op toeren te komen en er hoeft geen arm te bewegen. De controller van de SSD stuurt simpelweg een elektrisch signaal naar het juiste adres op de chip en de data is direct beschikbaar.

Toegangstijd en willekeurige leesacties

Hoewel de maximale doorvoersnelheid van grote bestanden bij een SSD indrukwekkend is, zit de echte winst voor de consument in de toegangstijd. Een besturingssysteem zoals Windows of macOS is constant bezig met het lezen en schrijven van duizenden kleine systeembestandjes. Een harde schijf heeft daar enorm veel moeite mee, omdat de leeskop als een bezetene heen en weer moet schieten. Een SSD kan deze willekeurige lees- en schrijfopdrachten (random read/write) nagenoeg gelijktijdig verwerken met een verwaarloosbare vertraging. Dat is de reden waarom een pc met een SSD binnen enkele seconden opstart, terwijl een computer met een HDD daar soms minuten over doet.

©KanyaphatStudio

Van SATA naar NVMe-snelheden

Tot slot speelt de aansluiting een rol in de snelheidsontwikkeling. De eerste generaties SSD's gebruikten nog de SATA-aansluiting, die oorspronkelijk was ontworpen voor harde schijven. Hoewel dat al een flinke verbetering was, liepen snelle SSD's tegen de grens van deze aansluiting aan. Moderne computers maken daarom gebruik van het NVMe-protocol via een M.2-aansluiting. Deze technologie communiceert rechtstreeks via de snelle PCIe-banen van het moederbord, waardoor de vertragende tussenstappen van de oude SATA-standaard worden overgeslagen. Hierdoor zijn snelheden mogelijk die vele malen hoger liggen dan bij de traditionele harde schijf.

Populaire merken voor SSD's

Als je op zoek bent naar een betrouwbare en snelle SSD, is er een aantal fabrikanten dat de markt domineert. Samsung wordt door velen gezien als de marktleider op het gebied van flashgeheugen en staat bekend om de uitstekende prestaties van hun EVO- en PRO-series. Daarnaast is Western Digital (WD) een vaste waarde; dit merk heeft de transitie van traditionele harde schijven naar SSD's succesvol gemaakt met hun kleurgecodeerde (Blue, Black en Red) series voor verschillende doeleinden. Ook Transcend is een uitstekende keuze; dit merk staat al jaren bekend om zijn betrouwbare geheugenproducten en biedt duurzame SSD's die lang meegaan. Tot slot bieden merken als Kingston en Seagate betrouwbare alternatieven die vaak net iets vriendelijker geprijsd zijn, zonder dat je daarbij veel inlevert op stabiliteit.

▼ Volgende artikel
AI zonder programmeren: Zo bouw je je eigen chatbot
© ID.nl
Huis

AI zonder programmeren: Zo bouw je je eigen chatbot

Misschien heb je wel eens een vraag gesteld aan een AI-chatbot als ChatGPT, Microsoft Copilot of Perplexity. Maar hoe ontwerp je zelf nu zo'n chatbot? Met de juiste tools is daar zelfs weinig tot geen programmeerwerk voor vereist. We bekijken twee uiteenlopende oplossingen.

Een AI-chatbot is een digitale gesprekspartner die wordt aangedreven door kunstmatige intelligentie. Meestal is de intelligentie gebaseerd op een taalmodel dat is getraind om mensachtige gesprekken te voeren. In tegenstelling tot traditionele op regels gebaseerde chatbots, die alleen vooraf ingestelde antwoorden geven, kan een AI-chatbot vrije tekst begrijpen en ‘natuurlijke’ reacties geven.

In dit artikel kijken we naar het bouwen van een eigen chatbot die je op je desktop of mobiel kunt gebruiken en zelfs op een eigen website kunt plaatsen. We bespreken twee manieren. De eenvoudigste is een no-code chatbotplatform dat het AI-gedeelte achter de schermen afhandelt en je via een gebruiksvriendelijke interface laat bepalen hoe de gespreksflow verloopt. Typische voorbeelden zijn Chatfuel en Chatbot voor zakelijke toepassingen. Daarnaast zijn er de meer toegankelijke Poe en Coze, die we hier behandelen. Onze tweede oplossing is technischer, maar flexibeler. Daarbij gebruik je de Application Programming Interface (API) van een AI-taalmodel om de AI-functionaliteit in je eigen omgeving te integreren. Hiervoor werken we graag met de online omgeving Google Colab.

Poe

Laten we starten met een gebruiksvriendelijke optie: het no-code chatbotplatform Poe (www.poe.com). Je kunt hier ook de app voor desktop of mobiel downloaden en installeren, met vrijwel dezelfde interface en functies als in de browser. De eerste keer maak je een account aan of meld je je aan met je Google- of Apple-account. Via Bots and apps kun je met allerlei AI-chatbots praten, maar in dit geval willen we vooral een eigen chatbot maken. Concreet gaat het om het creëren van een eigen ‘persona’ binnen een gekozen AI-model. Zo’n persona kun je zien als het perspectief, de rol of identiteit die je een AI-bot meegeeft.

Klik hiervoor op Create +. Je krijgt nu verschillende opties, zoals Image generation bot, Video generation bot en Prompt bot. Wij kiezen dit laatste.

Poe bestaat ook als desktop-app en biedt toegang tot vele tientallen AI-modellen.

Creatie

Je hoeft nu eigenlijk alleen maar een onlineformulier in te vullen. We doorlopen kort de belangrijkste onderdelen. Naast het gekozen bottype moet je een naam verzinnen. Omdat deze deel uitmaakt van de url, kies je bij voorkeur een originele, korte naam in kleine letters. Voeg ook een beschrijving toe, die zichtbaar is voor gebruikers van je bot.

Bij Base bot selecteer je een geschikt AI-model, bijvoorbeeld Claude-Haiku-3, GPT-4o-mini, GPT-5 of Grok-4. Afhankelijk van het model gelden er soms beperkingen. Poe-abonnees krijgen doorgaans uitgebreidere toegang tot de duurdere modellen.

Bij Prompt beschrijf je nauwkeurig en uitgebreid hoe de bot moet reageren. De optie Optimize prompt for Previews kun je uitgeschakeld laten. Vul bij Greeting message een welkomstwoord in dat de bot bij elke start toont. Het onderdeel Advanced kun je eigenlijk ongemoeid laten, maar interessant is wel dat je bij Custom temperature het ‘creativiteitsgehalte’ van de bot kunt instellen: hoe hoger de waarde, hoe creatiever en onvoorspelbaarder.

Bij Access kies je de zichtbaarheid van je bot. Wellicht is Only people with the access link de handigste optie, waarna de url zichtbaar wordt en je deze kunt verspreiden. Klik bovenin op Edit picture en kies of ontwerp een passend pictogram. Is alles ingevuld, klik dan onderin op Publish. Je bot is nu klaar voor gebruik. Om je bot te bewerken, hoef je deze maar bij Bots and apps te selecteren en via het knopje met de drie puntjes op Edit te klikken. Ook de optie Delete is beschikbaar.

Geef duidelijk aan wat je bot precies moet doen.
GPT's van OpenAI

Binnen de omgeving van OpenAI (https://chat.openai.com) kun je ook je eigen AI-chatbots maken, de zogeheten GPT’s. Hiervoor heb je wel een plusabonnement nodig (23 euro per maand). Je bent daarbij ook beperkt tot de GPT-modellen van OpenAI, maar je kunt je creaties wel delen via een link of in de GPT-store.

In het kort werkt dit als volgt. Meld je aan en klik links op GPT’s. Klik rechtsboven op + Maken. Via Configureren stel je alles handmatig in, maar via Maken kan het ook ‘al converserend’. Beschrijf kort wat je GPT moet doen en voor wie. Laat de tool een naam en profielfoto voorstellen en beantwoord de vragen om toon en werking af te stemmen. Test je GPT in de preview en ga daarna naar Configureren, waar je naam, beschrijving, instructies en gespreksopeningen ziet. Bij Kennis kun je bestanden uploaden zodat je GPT ook informatie uit je eigen documenten haalt. Via Nieuwe handeling maken koppel je eventueel acties aan externe API’s, gebruik alleen API’s die je vertrouwt. Bevestig met Maken en bepaal hoe je je GPT deelt: Alleen ik, Iedereen met de link of GPT-winkel (in een zelfgekozen categorie). Rond af met Opslaan. Je kunt de link (https://chatgpt.com/g/<code><naam>) daarna kopiëren en verspreiden. Via GPT’s / Mijn GPT’s kun je eerder gemaakte GPT’s bewerken of verwijderen.

Je kunt ook je ook eigen ‘chatbots’ (GPT’s) ontwerpen, gebruiken en met anderen delen.

Poe biedt ook geavanceerdere mogelijkheden als een Server bot-type (waarmee je ook andere API’s kunt aanroepen). Via Knowledge base kun je verder eigen informatiebronnen toevoegen waaruit de bot kan putten. Voor complexere bots gebruiken we toch liever het no-code platform Coze (www.coze.com) dat veel extra opties kent. Meld je aan met je Google-account, klik op + Create in de linkerkolom en daarna op + Create bij Create agent.

Coze

Coze gebruikt de term agent in plaats van bot om duidelijk te maken dat je er een digitale assistent mee kunt maken die niet alleen met een AI-model antwoorden geeft, maar ook geheugen of context kan gebruiken en meerdere kanalen kan bedienen, zoals een website of een Discord-server, maar zover gaan we hier niet.

Vul een passende naam voor je bot of agent in en schrijf een korte maar duidelijke omschrijving, bijvoorbeeld “Deze bot haalt allerlei informatie uit onze eigen documenten rond computerbeveiliging.” Laat Personal geselecteerd bij Workspace en klik linksonder op het knopje om een geschikt pictogram te uploaden of klik op het sterretje om er een te laten genereren. Klik daarna op Confirm.

De start van je eigen AI-chatbot (of agent) in Coze.

Uitwerking

Je komt nu in je dashboard waar je de bot verder vorm kunt geven. Ontwerp de persona door in het linkerdeelvenster een uitvoerige omschrijving van de bot in te vullen. Optimaliseer deze omschrijving snel met het blauwe knopje Auto Optimize prompt rechtsboven. Na bevestiging met Auto-optimize werkt Coze meteen een geoptimaliseerde prompt uit voor de persona. Klik op Replace om deze te gebruiken. In het rechterdeelvenster kun je je bot direct testen. De antwoorden komen uit de kennisdatabank van het geselecteerde model (zoals GPT-4o).



Wil je dat de bot ook uit eigen bronnen put, dan moet je deze eerst uploaden. Dit doe je in het middelste deelvenster, bij

Knowledge, waar je uit Text, Table en Images kunt kiezen. Klik op het plusknopje bij bijvoorbeeld Text en daarna op Create knowledge. Selecteer Text format en geef een naam aan je informatiebundel. Je kunt data ophalen uit bronnen als Notion of Google Doc, maar wij kiezen voor Local documents om eigen bestanden te uploaden. Klik op Create and import en versleep de gewenste documenten naar het venster. Klik daarna op Next (3x) en wat later zijn je documenten verwerkt. Rond af met Confirm en met Add to Agent rechtsboven. Je vindt je informatiebundel nu terug bij Knowledge en de bot put voortaan (ook) uit deze gegevens.

Om je bot beschikbaar te maken, klik je rechtsboven op Publish en daarna op Confirm. Je kunt hem op diverse platformen publiceren, onder meer in de Coze Agent Store. Selecteer een passende categorie en bevestig met Publish.

Laat AI je helpen bij het ontwerpen van een optimale persona.

Extra's

Daarnaast biedt Coze nog diverse andere nuttige opties, zoals talrijke plug-ins. Klik hiervoor op het plusknopje bij Plugins of gebruik het A-knopje om automatisch geschikte plug-ins te laden op basis van je persona-beschrijving. Deze kun je meteen inzetten, eventueel na optimale afstelling via het tandwielpictogram.

Je kunt de functionaliteit van je bot eenvoudig uitbreiden met talrijke plug-ins.

API-sleutels

No code-platformen als Poe en Coze zijn handig, maar wil je meer flexibiliteit en schrik je niet terug voor enige basiscodering, dan werk je beter met de API van een AI-model. Deze fungeert als tussenpersoon die je script en de AI-dienst laat communiceren via een set regels en commando’s. We gaan uit van de API van OpenAI (GPT) en maken eerst een sleutel aan om de API-interface te gebruiken. Ga naar https://platform.openai.com/api-keys, meld je aan met je account (zoals Google) en klik op +Create new secret key. Geef de sleutel een naam, bijvoorbeeld aibot, en klik op Create secret key. Klik daarna op Copy en bewaar de sleutel op een veilige plek. Rond af met Done: de sleutel is nu toegevoegd. Je kunt deze hier op elk moment ook weer intrekken.

Je hebt een sleutel nodig om de API te kunnen gebruiken.

Interactie

Een snelle manier om een script te maken dat deze API aanroept, is via het gratis Google Colab (https://colab.research.google.com), een online notitieboek voor Python. Meld je aan met je Google-account, klik op + Nieuw notebook of ga naar Bestand en kies Nieuw notebook in Drive, en geef het ipynb-bestand (Interactive PYthon NoteBook) een zinvolle naam. Het notebook wordt automatisch in je Google Drive bewaard en is bereikbaar via het pictogram met de oranje cirkels.

Klik nu op + Code voor je eerste codecel, waarmee je de OpenAI-bibliotheek installeert:

!pip install openai

Voer dit uit met het pijlknopje en klik vervolgens op + Code voor de tweede cel met de volgende code:


from openai import OpenAI

client = OpenAI(api_key="<je_API-sleutel>")

response = client.chat.completions.create(

    model="gpt-3.5-turbo",

    messages=[{"role": "user", "content": "Wat weet je over Haarlem( Nederlands)?"}]

)

print(response.choices[0].message.content)


Je laadt hierbij eerst de geïnstalleerde Python-bibliotheek en zet je geheime sleutel in de clientconfiguratie. Vervolgens stuur je een chataanvraag naar OpenAI en bewaar je het antwoord in de variabele ‘response’. Vervolgens haal je de tekst van het (eerste) antwoord op en druk je dit af in de uitvoer van de code-cel.

Een eenvoudige interactie tussen je script en GPT via de API.

Eigen chatbot

 We gaan nu een stap verder en maken er een heuse chatbot van die via een while-lus een doorlopend gesprek kan voeren:


from openai import OpenAI

client = OpenAI(api_key="<je_API-sleutel>")

messages=[

    {"role":"system","content":"Je beantwoordt elke prompt leuk, maar correct, met een rijmschema zoals ABAB of ABBA"}]

while True:

  user_input=input("Jij:")

  if user_input.lower() in ["stop","exit","quit"]:

    break

  messages.append({"role":"user","content":user_input})

  response=client.chat.completions.create(

      model="gpt-4o",messages=messages)

  bot_reply=response.choices[0].message.content

  print("Bot:",bot_reply)

  messages.append({"role":"assistant","content":bot_reply})


Zolang de gebruiker geen stopwoord invoert, blijft de lus actief. De bot antwoordt in de stijl en taal die je zelf hebt vastgelegd in de systeemrol (zie coderegel 3). Met de methode-aanroep messages.append voeg je telkens een nieuw bericht van zowel de gebruiker (user) als de bot (assistant) toe aan de gespreksgeschiedenis.

Mocht je ergens een fout hebben gemaakt in je script, dan is de kans groot dat je via de knop Fout uitleggen nuttige feedback krijgt en met de knop Accepteren (en uitvoeren) de fout zelfs automatisch kunt laten verbeteren.

In het kader ‘Mooi gepresenteerd’ lichten we kort toe hoe je dit script bijvoorbeeld ook op een eigen webpagina kunt laten draaien.

Onze rijmende chatbot wordt wakker geschud vanuit Colab.
Mooi gepresenteerd

Je Colab-script werkt, maar het oogt niet fraai en je wilt het natuurlijk mooi gepresenteerd met anderen delen. Dit doe je het makkelijkst met Gradio, een opensource-Python-bibliotheek waarmee je snel een webinterface rond je script bouwt. Installeer en importeer daarvoor eerst Gradio in je Colab-omgeving:

!pip install -q gradio

import gradio

Via www.kwikr.nl/colabcode vind je de code (als py-bestand) waarmee je rond het Colab-script met Gradio een eenvoudige webinterface genereert. Deze verschijnt in je Colab-omgeving, maar je krijgt ook een publieke url te zien waar je de interface rechtstreeks kunt openen (https://<code>.gradio.live).

Dankzij de volgende aanroep in de laatste coderegel kunnen bezoekers van deze webpagina je chatbot-script ook als PWA-app op hun pc bewaren en starten:

demo.launch(share=True,pwa=True)

Een alternatief is deze webpagina via een <iframe>-instructie in de html-code van je eigen site op te nemen:

<iframe src=https://<code>.gradio.live></iframe>

Gradio heeft een eenvoudige webinterface gecreëerd voor ons chatbotscript.