DEV Community

Hari Bantwal
Hari Bantwal

Posted on • Edited on

OCI Instance with External Block Volume

There are moments when simple tasks can slow down our progress, often because they're not part of our regular routine. A recent experience brought this to my attention when I decided to delve into self-hosting for Windmill.dev and Supabase.

I realized that I needed external references to navigate the foundational aspects due to the multitude of available approaches. This post serves as a record of this experience, with the hope that the lessons learned can be valuable in future, more intricate endeavors.


Objective: Provision Instance in OCI, with external Block volumes to cater to Different Docker Services


Create compute instance through OCI Console
Create Instance

With below information:

Image: Oracle Linux 8
Shape: Ampere VM.Standard.A1.Flex
Cost: CHF 2.00/month
Subnet: Public
Add SSH Keys: Yes


Create Block Volumes through OCI Console
Create Block Volume

With below information:

Volume size: 50 GB Estimated Price: CHF 0.02301885/GB
Volume performance: Balanced 10 VPUs at CHF 0.00153459/PU/GB
IOPS: 25,000 IOPS (60 IOPS/GB)


Attach the Block Volume to the Instance
Navigate to Attached Instances on Block Volume Screen
Attach with below information

Attachment type: ISCSI
Access Type: Read/Write
Instance: Created in Step 1
Device path: /dev/oracleoci/oraclevdb


Run iSCSI commands & information

iSCSI commands to connect should be run using the commands shown "Attached Block Volumes"

Image description

Remote SSH to the Instance to run the commands

ssh -i <Your SSH Private Key> opc@<PUBLIC_IP> sudo iscsiadm -m node -o new -T ... sudo iscsiadm -m node -o update -T ... sudo iscsiadm -m node -T ... 
Enter fullscreen mode Exit fullscreen mode

Create Disk Partition, Create File System Mount File System

sudo fdisk -l /dev/oracleoci/oraclevdb sudo mkfs -t ext4 /dev/oracleoci/oraclevdb 
Enter fullscreen mode Exit fullscreen mode

Mount file system

sudo mkdir /vol sudo mount /dev/oracleoci/oraclevdb /vol 
Enter fullscreen mode Exit fullscreen mode

OCI Block Volume is now mounted on Instance under the path /vol

Entry in /etc/fstab file for mounting after instance restart

/dev/oracleoci/oraclevdb /var/html-bv ext4 defaults,_netdv,nofail 0 2


How to Detach

  • Unmount the drive
sudo umount /vol 
Enter fullscreen mode Exit fullscreen mode
  • Run the disconnect commands
sudo iscsiadm -m node -T iqn.... sudo iscsiadm -m node -o delete -T iqn.... 
Enter fullscreen mode Exit fullscreen mode

Find the commands below iSCSI commands & information

Image description

  • Detach the instance

Blockvoulume is extended, How to make it available

After extending the Blockvolume, commands to run for repartition

 ubuntu@instance-wordpress-template-755807:~$ sudo parted /dev/oracleoci/oraclevdb GNU Parted 3.4 Using /dev/sdb Welcome to GNU Parted! Type 'help' to view a list of commands. (parted) unit s (parted) print Model: ORACLE BlockVolume (scsi) Disk /dev/sdb: 4294967296s Sector size (logical/physical): 512B/4096B Partition Table: msdos Disk Flags: Number Start End Size Type File system Flags 1 2048s 2147483647s 2147481600s primary ext4 (parted) rm 1 Warning: Partition /dev/sdb1 is being used. Are you sure you want to continue? Yes/No? Yes Error: Partition(s) 1 on /dev/sdb have been written, but we have been unable to inform the kernel of the change, probably because it/they are in use. As a result, the old partition(s) will remain in use. You should reboot now before making further changes. Ignore/Cancel? Ignore (parted) mkpart Partition type? primary/extended? primary File system type? [ext2]? ext4 Start? 2048 End? 100% (parted) quit Information: You may need to update /etc/fstab. 
Enter fullscreen mode Exit fullscreen mode

Resize the extended Block Volume

sudo resize2fs /dev/oracleoci/oraclevdb1 df -h 
Enter fullscreen mode Exit fullscreen mode

Top comments (0)