Skip to content
/ Michaël Hompus

In the past few years, I have presented multiple sessions all around the world, although mostly virtual. Presenting for a live crowd was something I only did inside The Netherlands before. With restrictions being lifted during 2022, new opportunities presented themselves and I was able to be in front of a live audience again, even outside the country!

In the past few years, I have presented multiple sessions all around the world, although mostly virtual. Presenting for a live crowd was something I only did inside The Netherlands before COVID-19 struck the world.

With restrictions being lifted during the year of 2022, new opportunities presented themselves and I was able to be in front of a live audience again and on some occasions, even outside the country!

dotNed meeting February

This was not my first time doing a dotNed user group session. The session was still only online. It was interesting for me, because it was the first time, I would give my Azure cost management related session.

In Dutch it was called Ons bint zuunig, setting the theme with Zeeuws meisje.

AzureLive

Still in a hybrid setup, the audience of AzureLive could watch the streams from home. However, half of the presenters joined physically at the same location where the recordings took place. It was nice to meet new people after doing everything virtually.

This was also my first time meeting Henk Boelman and Suzanne Daniels (my MCs), Stacy Cashmore, and Barbara Forbes as fellow speakers, which I would join again at later conferences.

dotNed Saturday

dotNed Saturday is an event where I have had the honor of speaking for multiple years now. I already did a talk about Azure Key Vault at the 2018 edition, but for this year the content was updated to reflect the current state of the service.

I was joined by (amongst others) Sander Molenkamp, Roland Guijt, Marcel de Vries, and Dennis Doomen as fellow speakers.

IglooConf: Midsummer

The first time I had to travel by plane to get to my speaking gig!

Not only was IglooConf a very nice 2-day conference in Helsinki 🇫🇮, it also meant multiple days being highly involved with the other speakers. My session was about Dapr, and how it can let you postpone architectural choices to a later moment in time.

I really had a blast together with Magnus Mårtensson, Glenn Colpaert, Alan Smith, Karl Ots, Mark Brown, Roberto Freato, Sakari Nahi, Rik Hepworth, Andreas Erben, Pieter Vandenheede, and Stacy. Many of whom I will join at later conferences again.

Developer Week

This time I could take the train to the conference. Joined by my colleagues Hanno Embregts and Peter Wessels we traveled to Developer Week in Nürnberg 🇩🇪.

Originally, I would only do my session on Dapr. Due to many speaker cancellations, I also presented my sessions about Azure cost management and Using your source code to generate documentation.

During the conference I was able to join up with Dennis and Roland again and have the privilege to spend some time with Rob Richardson, Matteo Emili, Salvatore Merone, Scott Guymer, and Niek Palm. Specially meeting Niek was fun as we went to school together over 25 years ago.

Azure Fest

For this one I did not have to travel far as Azure Fest was hosted at the Info Support office. My session was about Azure cost management again, apparently a hot topic these days.

This was the first time meeting Sam Vanhoutte as speaker, but also joining up again with Sander, Henk and Barbara for a second time.

K!K live

K!K live is a smaller meet-up in the Netherlands. Still, I had some nice interaction with the audience during and after my session about Azure cost management.

CloudBrew

This was my last session of 2022. (I had to cancel the Dev-Cloud and .NET Developer conferences in Köln 🇩🇪 due to personal circumstances).

I traveled, by car this time, to the nice city of Mechelen 🇧🇪.

Besides my session about Azure cost management, CloudBrew felt like a nice reunion meeting Rik, Barbara, Roberto, Sam, and Pieter again.

2023

Will I be speaking as often in 2023? I do not know; it is up to the people judging CFPs and hoping my talks fit in with their programs. But in January I am certain to hit the stage again.

NDC London

After being a speaker at the NDC London 2021 online edition, this time I will be traveling by train to London 🇬🇧, together with my colleague Sander.

I am looking forward to meeting Andreas, Magnus, Marcel, Pieter, Rob, Sander, Stacy, and Suzanne again on stage!

Filed under Azure, C#
Last update:
/ Michaël Hompus

When adding emoticons to your PowerPoint slides, sometimes the rendering might not be as expected. For example, PowerPoint renders the emoticon only in a textual, monochrome variant on the slide. So, how can we influence this behavior?

When adding emoticons to your PowerPoint slides, sometimes the rendering might not be as expected.

For example, when selecting the desktop emoticon on my system, PowerPoint renders the emoticon only in a textual, monochrome variant on the slide.

After selecting the desktop emoticon, it is rendered as text, not an emoji.
After selecting the desktop emoticon, it is rendered as text, not an emoji.

Note

I encountered this behavior multiple times myself and can depend on the machine used to view the PowerPoint presentation, while other persons looking at the same file at the same time can see the emoji rendering.

So, how can we influence this behavior?

Unicode variation selector

I discovered an old post by Matias Singers about Unicode symbol as text or emoji.
The article describes the Unicode variation selectors.

By adding variation selector-15, or variation selector-16, after an emoticon the rendering of the character can be influenced.

Switch from text to emoji

Using variation selector-16 after the emoticon, the character will be forced to be rendered as a colorful image. Inserting character U+FE0F after the desktop character will change it in the expected emoji:

The desktop emoticon rendered as a colorful emoji after adding variation selector-16.
The desktop emoticon rendered as a colorful emoji after adding variation selector-16.

Switch from emoji to text

This can also be used the other way around. When a more textual or monochrome variant would be beneficial, this can be forced to render as well.

Let’s start with the house with garden emoticon.

The house with garden emoticon rendered as a colorful emoji.
The *house with garden* emoticon rendered as a colorful emoji.

Using variation selector-15 after the emoticon, the character will be forced to be rendered in a textual fashion. Inserting character U+FE0E after the house with garden character will change it into a monochrome house with a flower:

The emoticon rendered in a textual fashion after adding variation selector-15.
The emoticon rendered in a textual fashion after adding variation selector-15.
Filed under Office
Last update:
/ Michaël Hompus

Learn how to stack emoticons in PowerPoint to create engaging and visually appealing slide titles. Bring your presentations to life with this quick and easy tip!

Looking to make your PowerPoint slide titles more engaging and eye-catching? When a single emoticon doesn’t quite capture the message you want to convey, why not combine multiple emoticons?
In this quick guide, I will show you how to stack emoticons in PowerPoint to create compelling and meaningful slide titles.

Let’s take this boring slide:

Slide with only the title text "Run locally"
Slide with only the title text "Run locally"

Note

I am only showing the top-left corner, the rest of the slide is even more boring.

We can add an emoticon to emphasize the running part.

Slide with the title "Run locally" prefixed with a running person emoticon
Slide with the title "Run locally" prefixed with a running person emoticon

But what if we also want to include the local part?
Let’s add a house emoticon.

Slide with the title "Run locally" prefixed with both a house and running person emoticon
Slide with the title "Run locally" prefixed with both a house and running person emoticon

This does not give the right feeling yet, what if we could combine the two a bit more?

Let’s merge these two emoticons to set a scene.

  1. Select the running person emoticon and choose Font > Subscript

    Font menu with the Subscript option checked
    Font menu with the Subscript option checked
  2. Select the house emoticon and choose Font > Character Spacing > Condensed by 25pt

    Font menu with the Character Spacing set to Condensed by 25pt
    Font menu with the Character Spacing set to Condensed by 25pt

Note

The actual value might depend on your font-size and emoticon-width.

Slide with the title "Run locally" prefixed with a person running in front of a house emoticon
Slide with the title "Run locally" prefixed with a person running in front of a house emoticon

That is it! Much better!

More examples

The same technique can be used to combine several other emoticons in this way.
Just some random examples:

  1. Run through the street
  2. Finish 3rd in a cycling competition
  3. Choose something from the menu
  4. Sales of dinosaurs has increased recently
  5. Save that thread
  6. Comment on the shopping cart contents
Examples of several combinations of emoticons in PowerPoint
Examples of several combinations of emoticons in PowerPoint
Filed under Office
Last update:
/ Michaël Hompus

I recently joined the Advent of Code 2021. During the first 25 days of December, the challenges made me (re)discover many possibilities with C#, some that are long available but maybe not that well known. I share my code and list of concepts that might inspire you to discover a feature you were not aware of yet!

Although Eric Wastl has been organizing the Advent of Code since 2015. I only discovered it recently when some colleagues invited me to join the 2021 edition.

Advent of Code is an Advent calendar of small programming puzzles for a variety of skill sets and skill levels that can be solved in any programming language you like.

About

During the first 25 days of December, the challenges made me (re)discover many possibilities with C#, some that are long available but maybe not that well known.

Solutions

I had a blast (and some frustration 😉) solving the challenges, starting early morning, every day.

Some of the noteworthy concepts I have used:

  • Records, both class (C# 9.0) and struct (C# 10.0) based.
  • Converting data (bits to int with bit shifting, char to decimal using addition or subtraction, etc.).
  • Efficiently read and slice strings, arrays, and lists using Index and Range (C# 8.0).
  • Work with Stack<T> (.NET Framework 2.0), SortedSet<T> (.NET Framework 4.0), and HashSet<T> (.NET Framework 4.7.2).
  • Using init only setters, with expressions and target typed new expressions (all C#9.0).
  • Many, many more…

I have put all my code and descriptions in my AdventOfCode2021 repo on GitHub.
Maybe this also inspires you to discover a new feature you were not aware of yet!

Filed under C#
Last update:
/ Michaël Hompus

In a previous article I described how to configure an Azure SQL database failover group for high availability across multiple regions. But what if you want to limit network traffic to a database in this failover group to only your private networks? In this article I show how to make a SQL database failover group reachable via the Private Link service and make sure the database stays reachable after a failover.

In a previous article I described how to configure an Azure SQL database failover group for high availability across multiple regions.

But what if you want to limit network traffic to a database in this failover group to only your private networks?

In this article I show how to make a SQL database failover group reachable via the Private Link service and make sure the database stays reachable after a failover.

Note

This article will continue on the environment created in the previous article where I described how to create an Azure SQL Database Failover Group with the Azure CLI.
The examples are using the Azure CLI in a bash shell.

Creating a virtual network

First create a virtual network which can be used to access the SQL database privately.

Azure CLI
az group create --name "hompus-vnet-we-rg" \
--location "westeurope"
az network vnet create --resource-group "hompus-vnet-we-rg" \
--name "hompus-we-vnet" \
--location "westeurope" \
--address-prefix "10.164.0.0/16" \
--subnet-name "default" \
--subnet-prefix "10.164.0.0/24"

Controlling traffic from and to private endpoints is not possible with network security groups (NSG).

However, to connect a private endpoint to a subnet, the private endpoint network policy has to be disabled explicitly. This is done with the az network vnet subnet update command.

Azure CLI
az network vnet subnet update --resource-group "hompus-vnet-we-rg" \
--name "default" \
--vnet-name "hompus-we-vnet" \
--disable-private-endpoint-network-policies true

Creating the private endpoint

For each of the SQL servers in the failover group we need to add a private link. First retrieve the id of the server using the az sql server show command.

To create the private endpoint, use the az network private-endpoint create command. Both the name and connection name need to be provided, which can be the same.

Specify the SQL server resource id and the name of the subnet that are on both sides of the connection.

Do the same for the other SQL server in the failover group.

Azure CLI
# West Europe
sqlServerIdWE=$(az sql server show --resource-group "hompus-db-we-rg" \
--name "hompus-db-we-server" \
--query "id" \
--output "tsv")
az network private-endpoint create --resource-group "hompus-vnet-we-rg" \
--name "hompus-db-we-server-pe" \
--connection-name "hompus-db-we-server-pe" \
--private-connection-resource-id $sqlServerIdWE \
--group-id "sqlServer" \
--vnet-name "hompus-we-vnet" \
--subnet "default"
# North Europe
sqlServerIdNE=$(az sql server show --resource-group "hompus-db-ne-rg" \
--name "hompus-db-ne-server" \
--query "id" \
--output "tsv")
az network private-endpoint create --resource-group "hompus-vnet-we-rg" \
--name "hompus-db-ne-server-pe" \
--connection-name "hompus-db-ne-server-pe" \
--private-connection-resource-id $sqlServerIdNE \
--group-id "sqlServer" \
--vnet-name "hompus-we-vnet" \
--subnet "default"

Creating the private DNS zone

When any application connected to the private network resolves the DNS name hompus-db-group.database.windows.net the response will contain the external IP-address. This defeats the purpose of the network and endpoint.

bash
michael@hompus-we-vm:~$ nslookup hompus-db-group.database.windows.net
Non-authoritative answer:
hompus-db-group.database.windows.net
canonical name = hompus-db-we-server.database.windows.net.
hompus-db-we-server.database.windows.net
canonical name = hompus-db-we-server.privatelink.database.windows.net.
hompus-db-we-server.privatelink.database.windows.net
canonical name = dataslice9.westeurope.database.windows.net.
dataslice9.westeurope.database.windows.net
canonical name = dataslice9westeurope.trafficmanager.net.
dataslice9westeurope.trafficmanager.net
canonical name = cr7.westeurope1-a.control.database.windows.net.
Name: cr7.westeurope1-a.control.database.windows.net
Address: 52.236.184.163

To resolve the correct IP-address, create a private DNS zone using the az network private-dns zone create command. The name must be privatelink.database.windows.net. Connect the created DNS zone to the virtual network with the az network private-dns link vnet create command.

A linked private DNS zone allows virtual machines on the virtual network to be automatic added as entries in the DNS zone. This is not relevant for the private link DNS zone, so this option can be disabled.

Azure CLI
az network private-dns zone create --resource-group "hompus-vnet-we-rg" \
--name "privatelink.database.windows.net"
az network private-dns link vnet create \
--resource-group "hompus-vnet-we-rg" \
--name "pdns-link-hompus-we-vnet" \
--zone-name "privatelink.database.windows.net" \
--virtual-network "hompus-we-vnet" \
--registration-enabled false

The next step is to add the private endpoints to the DNS zone. This does not require knowledge of the actual IP-addresses that have been assigned on the network. With the az network private-endpoint dns-zone-group create command the endpoint is registered, and the private IP-address will be resolved.

Terminal window
# West Europe
az network private-endpoint dns-zone-group create \
--resource-group "hompus-vnet-we-rg" \
--name "hompus-db-zone" \
--endpoint-name "hompus-db-we-server-pe" \
--private-dns-zone "privatelink.database.windows.net" \
--zone-name "hompus-db-group"
# North Europe
az network private-endpoint dns-zone-group create \
--resource-group "hompus-vnet-we-rg" \
--name "hompus-db-zone" \
--endpoint-name "hompus-db-ne-server-pe" \
--private-dns-zone "privatelink.database.windows.net" \
--zone-name "hompus-db-group"

Resolving the private endpoint

After the registration is done, any application connected to the private network will resolve the DNS name hompus-db-group.database.windows.net to the internal IP-address.

The DNS name for hompus-db-group.secondary.database.windows.net will point to the other server in the failover group.

bash
michael@hompus-we-vm:~$ nslookup hompus-db-group.database.windows.net
Server: 127.0.0.53
Address: 127.0.0.53#53
Non-authoritative answer:
hompus-db-group.database.windows.net
canonical name = hompus-db-we-server.database.windows.net.
hompus-db-we-server.database.windows.net
canonical name = hompus-db-we-server.privatelink.database.windows.net.
Name: hompus-db-we-server.privatelink.database.windows.net
Address: 10.164.0.4
bash
michael@hompus-we-vm:~$ nslookup hompus-db-group.secondary.database.windows.net
Server: 127.0.0.53
Address: 127.0.0.53#53
Non-authoritative answer:
hompus-db-group.secondary.database.windows.net
canonical name = hompus-db-ne-server.database.windows.net.
hompus-db-ne-server.database.windows.net
canonical name = hompus-db-ne-server.privatelink.database.windows.net.
Name: hompus-db-ne-server.privatelink.database.windows.net
Address: 10.164.0.5

After executing a failover, to DNS entries have swapped servers.

bash
michael@hompus-we-vm:~$ nslookup hompus-db-group.database.windows.net
Server: 127.0.0.53
Address: 127.0.0.53#53
Non-authoritative answer:
hompus-db-group.database.windows.net
canonical name = hompus-db-ne-server.database.windows.net.
hompus-db-ne-server.database.windows.net
canonical name = hompus-db-ne-server.privatelink.database.windows.net.
Name: hompus-db-ne-server.privatelink.database.windows.net
Address: 10.164.0.5
bash
michael@hompus-we-vm:~$ nslookup hompus-db-group.secondary.database.windows.net
Server: 127.0.0.53
Address: 127.0.0.53#53
Non-authoritative answer:
hompus-db-group.secondary.database.windows.net
canonical name = hompus-db-we-server.database.windows.net.
hompus-db-we-server.database.windows.net
canonical name = hompus-db-we-server.privatelink.database.windows.net.
Name: hompus-db-we-server.privatelink.database.windows.net
Address: 10.164.0.4

This proves that connections on the virtual network will use the private link to the SQL database, no matter which one is the current primary or secondary in the failover group.

It is also possible to connect virtual networks from other regions to the same SQL failover group, just iterate the same steps for each region.

Filed under Azure, SQL
Last update: