We needed to increase a file system which ran out of space. Luckily this file system was a logical volume. Unfortunately the volume group didn't have free space anymore.
As this machine is a virtual machine under VMware, the simplest solution would be to add a new virtual disk and declare it as a physical volume, extend the volume group and voilà, done. But in this case we wanted to increase the existing HDD and adapt the partitions. The logical partition /dev/sda5 is used as LVM PV, therefore it is part of an extended partition (/dev/sda3).
After the virtual disk's size was increased in vCenter, we started up Knoppix. My colleague used gparted to increase the size of the extended partition which worked like a charm. But he wasn't able to increase the logical partition (/dev/sda5) to fill up the rest of the extended partition. So I took a look at it. Indeed, in gparted nothing could be done.
I wanted to do it with the classic fdisk. To increase the logical partition it actually needs to be deleted and then recreated as a new partition - starting at the same sector as before and ending with the new (increased) end of the extended partition. Because the partition is not formatted after it is recreated, the data is not lost.
Before doing anything, I copied the output of fdisk -l as reference (and I created a VMware snapshot, just in case).
  
 
root@Microknoppix:~# fdisk -l /dev/sda 
 
Disk /dev/sda: 32.2 GB, 32212254720 bytes
  
255 heads, 63 sectors/track, 3916 cylinders, total 62914560 sectors
  
Units = sectors of 1 * 512 = 512 bytes
  
Sector size (logical/physical): 512 bytes / 512 bytes
  
I/O size (minimum/optimal): 512 bytes / 512 bytes
  
Disk identifier: 0x000ee3a4
  
 
   Device Boot      Start         End      Blocks   Id  System
  
/dev/sda1   *        2048     9764863     4881408   83  Linux
  
/dev/sda2         9764864    25389055     7812096   82  Linux swap / Solaris
  
/dev/sda3        25391102    62914559    18761729    5  Extended
  
/dev/sda5        25391104    41940991     8274944   8e  Linux LVM
  
 
So /dev/sda5 started at sector 25391104. Noted.
Let's delete the partition:
  
 
root@Microknoppix:~# fdisk /dev/sda 
 
Commmand (m for help): d 
Partition number (1-5): 5 
 
Command (m for help): w 
The partition table has been altered
  
 
Calling ioctl() to re-read partition table.
  
Syncing disks.
  
 
And now create the new partition, starting at sector 25391104:
root@Microknoppix:~# fdisk /dev/sda 
 
Commmand (m for help): p 
 
Disk /dev/sda: 32.2 GB, 32212254720 bytes
  
255 heads, 63 sectors/track, 3916 cylinders, total 62914560 sectors
  
Units = sectors of 1 * 512 = 512 bytes
  
Sector size (logical/physical): 512 bytes / 512 bytes
  
I/O size (minimum/optimal): 512 bytes / 512 bytes
  
Disk identifier: 0x000ee3a4
  
 
   Device Boot      Start         End      Blocks   Id  System
  
/dev/sda1   *        2048     9764863     4881408   83  Linux
  
/dev/sda2         9764864    25389055     7812096   82  Linux swap / Solaris
  
/dev/sda3        25391102    62914559    18761729    5  Extended
  
 
Commmand (m for help): n 
Partition type:
  
  p  primary (2 primary, 1 extended, 1 free)
  
  l  logical (numbered from 5)
  
Select (default p): l 
Adding logical partition 5 
First sector (25391165-62914559, default 25391165): 25391104 
Value out of range
  
First sector (25391165-62914559, default 25391165):
  
 
Damn it! Value out of range! 
The partition is not aligned and fdisk decided the new partition's start sector must begin with a proper alignment (although the previous partition was set up this way...).
As an alternative I also tried to create the partition with cfdisk but there I couldn't even tell cfdisk the start sector.
parted to the rescue! With parted I was able to create the new partition with the same start sector as before!
  
First print the partition table in parted. To show the sectors instead of the default (human readable Bytes) I used the "unit" command and set it to s (sectors):
  
 
root@Microknoppix:~# parted /dev/sda 
GNU Parted 2.3
  
Using /dev/sda
  
Welcome to GNU Parted! Type 'help' to view a list of commands.
  
(parted) unit s 
(parted) print 
Model: VMware Virtual disk (scsi)
  
Disk /dev/sda: 62914560s
  
Sector size (logical/physical): 512B/512B
  
Partition Table: msdos
  
 
Number  Start      End       Size       Type     File system    Flags
  
 1      2048s      9764863s  9762816s   primary  ext4           boot
  
 2      9764864s   9764863s  15624192s  primary  linux-swap(v1)
  
 3      25391102s  62914559s 37523458s  extended
  
 
And now create the new partition:
(parted) mkpart logical 25391104s -1s  
 
The mkpart command creates a new partition. The syntax is the following:
mkpart [part-type fs-type name] start end
In my mkpart command above I didn't define the fs-type as its optional and I'm not about to create a new filesystem here, only a logical partition. And that's the first argument (part-type).
  
The next arguments (25391104s and -1s) define the start and the end of the new partition. By default mkpart would expect the start and end in Bytes/MB/GB but if the argument is followed with a 's', sectors can also be defined. -1s means that last usable sector of the disk. As we're within the extended partition this means pretty much use the last usable sector of the extended partition.
There was no error message or warning after the command. Let's verify with print again:
(parted) print 
Model: VMware Virtual disk (scsi)
  
Disk /dev/sda: 62914560s
  
Sector size (logical/physical): 512B/512B
  
Partition Table: msdos
  
 
Number  Start      End       Size       Type     File system    Flags
  
 1      2048s      9764863s  9762816s   primary  ext4           boot
  
 2      9764864s   9764863s  15624192s  primary  linux-swap(v1)
  
 3      25391102s  62914559s 37523458s  extended
  
 4      25391104s  62914559s 37523456s  logical
  
(parted) quit 
 
Yes, it worked! With parted I was able to force the starting sector of the partition.
Now I could increase the physical volume:
root@Microknoppix:~# pvresize /dev/sda5 
  Physical volume "/dev/sda5" changed
  
  1 physical volume(s) resize / 0 physical volume(s) not resized
  
 
vgdisplay/vgs now showed the available disk space in the volume group and an lvextend followed by resize2fs solved the disk space problem.
  
 
George from United Kingdom wrote on Jun 4th, 2020:
Thank you. What a brilliant description of how to use parted. I spent a few hours and this was exactly what I needed. 
I have a HP server with a RAID drive. I had extended the logical partion and wanted to then increase the size of the partion and file system. But... fdisk had originall set the start block to 2048, and after the logical drive was increased it then wanted me to recreate the partition starting at block 2560!!!!!
This helped me understand how I could use parted to manually set the start block. 
 
AWS Android Ansible Apache Apple Atlassian BSD Backup Bash Bluecoat CMS Chef Cloud Coding Consul Containers CouchDB DB DNS Databases Docker ELK Elasticsearch Filebeat FreeBSD Galera Git GlusterFS Grafana Graphics HAProxy HTML Hacks Hardware Icinga Influx Internet Java KVM Kibana Kodi Kubernetes LVM LXC Linux Logstash Mac Macintosh Mail MariaDB Minio MongoDB Monitoring Multimedia MySQL NFS Nagios Network Nginx OSSEC OTRS Observability Office OpenSearch PHP Perl Personal PostgreSQL PowerDNS Proxmox Proxy Python Rancher Rant Redis Roundcube SSL Samba Seafile Security Shell SmartOS Solaris Surveillance Systemd TLS Tomcat Ubuntu Unix VMWare VMware Varnish Virtualization Windows Wireless Wordpress Wyse ZFS Zoneminder Linux